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WARNING 

This equipment has been certified to comply with the limits for a class B 
computing device, pursuant to subpart J of part 15 FCC rules. Only 
peripherals (computer input/output devices, terminals, printers, etc.) 
certified to comply with the class B limits may be attached to this 
computer. Operation with non-certified peripherals is likely to result in 
interference to radio and TV reception. 


All cables used to connect to peripherals must be shielded and grounded. 
Operation with cables, connected to peripherals, which are not shielded 
and grounded may result in interference to radio and TV reception. 


This equipment meets or exceeds requirements for safety in the US 
(UL 478 5th Edition), Canada (CSA C22.2 No. 220), and Europe (IEC 380, 
IEC 435, IEC 950, and VDE 0806). 


This equipment has been tested for radio frequency emissions and has 
been verified to meet VDE 0871 Class B. 


This digital apparatus does not exceed the Class B limits for radio noise 
emissions set out in the radio interference regulations of the Canadian 
Department of Communications. 


Ce dispositif digital, s’il est utilise suivant les instructions et 
recommandations du constructeur, ne depasse pas les limites de la 
Classe B pour le bruit des frequences radio, etablies par les Regles sur 
l'interference radio du Ministere Canadian des Communications. 


RADIO FREQUENCY INTERFERENCE NOTICE 

This equipment generates and uses radio frequency energy and if not installed properly, that 
is, in strict accordance with the manufacturer’s instructions, may cause interference to radio 
and television reception. It has been type-tested and found to comply with the limits for a 
Class B computing device in accordance with the specifications in Subpart J of Part 15 FCC 
rules, which are designed to provide reasonable protection against interference in a 
residential installation. However, there is no guarantee that interference will not occur in a 
particular installation. If the equipment does cause interference to radio or television 
reception, which can be determined by turning the equipment off and on, the user is 
encouraged to try to correct the interference by one or more of the following measures: 

e ~=Reorient the receiving antenna. 

e Relocate the system with respect to the receiver. 

e@ Move the system away from the receiver. 


e Plug the system into a different outlet so that the system and receiver are on different 
branch circuits. 


@ Move the cables connected to the system to minimize the interference. 

e Tighten all screws on cables and the system housing. 

e Install blank panels, originally supplied with the system, in all unused card slots. 
If necessary the user should consult the dealer or an experienced radio/television technician 
for additional suggestions. The user may find the following booklet, prepared by the Federal 
Communications Commission, helpful: 


"How to Identify and Resolve Radio-TV Interference Problems" 


This booklet is available from the U.S. Government Printing Office, Washington, D.C. 20402. 
Stock No. 004-00398-5. 
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Additional copies of this manual or other Intel literature may be obtained from: 


Intel Corporation 

Literature Sales 

P.O. Box 58130 

Santa Clara, CA 95052-8130 


Intel Corporation makes no warranty of any kind with regard to this material, including, but not 
limited to, the implied warranties of merchantability and fitness for a particular purpose. Intel 
Corporation assumes no responsibility for any errors that may appear in this document. Intel 
Corporation makes no commitment to update nor to keep current the information contained in 
this document. 


Intel Corporation assumes no responsibility for the use of any circuitry other than circuitry 
embodied in an Intel product. No other circuit patent licenses are implied. 


Intel software and firmware products are copyrighted by and shall remain the property of Intel 
Corporation. Use, duplication, or disclosure is subject to restrictions stated in Intel's Software 
License Agreement, or in the case of software delivered to the U.S. government, in 
accordance with the software license agreement as defined in FAR 52.227-7013 


No part of this document may be copied or reproduced in any form or by any means without 
prior written consent of Intel Corporation. 


Intel Corporation retains the right to make changes to these specifications at any time, without 
notice. Contact your local sales office to obtain the latest specifications before placing your 
order. 
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The following are trademarks of Intel Corporation and its affiliates, and may be 


used only to identify Intel products: 


Above iMDDX 

BITBUS iMMX 
COMMputer Inboard 

CREDIT Insite 

Data Pipeline Intel® 

ETOX intel® 

Genius Intel376 

i486 Intel386 
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ICE inteligent Programming 
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MULTIBUS is a patented Intel bus. 
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PROMPT 
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PC, XT, and AT are trademarks of International Business Machines, Inc. 
Microsoft, MS-DOS, OS/2, and XENIX are registered trademarks of Microsoft 
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Multiplan is a trademark of Microsoft Corporation. 


UNIX is a trademark of AT&T. 
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MultiMate is a trademark of Ashton-Tate. 
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About This Manual 





PURPOSE 





This manual provides reference data for the Intel886™ MicroComputer Model 
300SX System Board. The Technical Reference Manual gives system designers 
sufficient information to allow them to integrate the board into systems, and to 
test and evaluate that integration. System designers may also use this manual on 
a continuing basis to support their customers, solve problems, or expand the 
system. For example, this manual may be used to: 


Design or select system components such as expansion boards, peripheral 
devices, and replacement parts 


Select or design systems and applications software 
Solve system integration and interfacing problems 
Troubleshoot at an advanced level 


Program complex applications and systems software such as device 
drivers, interrupt handlers, etc. 
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About This Manual 





LIBRARY PLAN 


This manual is the second in a set of three manuals written for the Intel386 
MicroComputer Model 300SX board. A brief description of these manuals is as 
follows: 


AUDIENCE 


XXXiV 


Intel386™ MicroComputer Mode! 300SX System Technical Reference 
Manual. This manual and its companion volume, /nte/386™ 
MicroComputer Model 300SX Board Technical Reference Manual, are 
written primarily for an Original Equipment Manufacturer (OEM), system 
engineer, or hardware or software designer. The system manual focuses 
on the major elements contained in the system module chassis. It provides 
a general description of the system, a brief overview of the system board, 
all internal interfaces to other components, and all external interfaces. 
Basic installation and removal procedures for system components and 
peripheral devices are also included. A detailed description of the system 
board is contained in a separate manual (see following). 


Intel386™ MicroComputer Model 300SX Board Technical Reference 
Manual. This manual describes the system board in detail, and is written 
for engineers who design system accessories and for programmers who 
require information on hardware and firmware specifications. 


Intel386™ MicroComputer Model 300SX User’s Guide. This manual is 
written for an end-user. It describes all system features, installation and 
operation of the system, how to install or remove system components, and 
basic troubleshooting procedures should problems occur. 


This manual is written for an Original Equipment Manufacturer (OEM), or a 
system engineer or hardware designer. As such, it assumes you are familiar with 
the general terminology used in the field of microprocessor and microcomputer 
design. 
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ORGANIZATION 


This manual is organized into 11 chapters and eight appendixes as follows: 


Chapter 1 


Chapter 2 


Chapter 3 


Chapter 4 


Chapter 5 


Chapter 6 


Chapter 7 


Chapter 8 


Chapter 9 


Chapter 10 


Board Overview — provides an overview of the 300SX board. 
Included is a list of features, a block diagram of the board, and 
a description of the feature set. 


Central Processing Core — describes the operation of the CPU, 
the 387™ numeric coprocessor, and the data and controller 
buffers. 


Intel 82335 High-integration Interface Device — presents an 
overview of the Intel 82335 and describes its internal functional 
blocks. 


Intel 82330/82331 Chip Set — describes the operation of the 
Intel 82330/82331 Chip Set which provides a high-integration 
interface for a PC-AT system. 


Communication Ports — describes the board's serial and 
parallel ports. 


Keyboard and Mouse Controller — describes the operation of 
the keyboard and mouse controller. 


Video Display Subsystem — describes the operation of the 
onboard graphics chip set and the digital-to-analog converter. 


Floppy Disk Drive Controller — describes the operation of the 
87072 onboard floppy disk drive controller. 


Intel ISA Bus Interface — introduces the ISA bus, provides 
general attributes of the ISA bus, and describes the ISA bus 
signals. 


External Interfaces — describes the external interfaces included 
on the board. 
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Chapter 11 


Appendix A 


Appendix B 


Appendix C 


Appendix D 


Appendix E 


Appendix F 


Appendix G 


Appendix H 


Glossary 


Index 


XXXxvi 


Power-on Self Test — describes the Power-on Self Test and the 
Setup utility stored in ROM. 


Specifications — provides specifications for the 300SX board. 


System BIOS Specifications — provides BIOS specifications for 
the 300SX board. 


Jumper Settings — provides jumper settings for the 300SX 
board. 


Changing CPU Speed — describes how to decrease the 
processor speed to 8 MHz. 


Messages — describes the various screen messages and error 
beep codes. Included are POST messages, run-time 
messages, 300SX board error messages, and beep codes. 
Device Mapping — provides tables that list mapping and 
addressing information related to 300SX board memory and 
onboard devices. 


Hot Keys — lists keystroke sequences used to invoke special 
system functions. 


Component Installation — describes how to install the Intel 
387SX numeric coprocessor and single in-line memory modules 
(SIMMs). 


List of standard acronyms and technical terms with definitions. 


Manual index. 
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HOW TO OBTAIN MORE INFORMATION 


You may be interested in obtaining further information about products and 
services relating to the Intel8386 MicroComputer Model 300SX System Board. Or 
you may require more detailed information than is provided in this manual. 


Please contact your local Intel Sales Office if you desire additional information. 


NOTATIONAL CONVENTIONS 


Certain notational conventions are used throughout this manual and others in the 
library. Refer to the glossary for specific definitions. Notational conventions 
include: 


system Throughout this manual, the term "300SX system" or "system" 
applies to the Intel386™ MicroComputer Model 300SX System. 


board Throughout this manual, the term "300SX board" or "board" 
applies to the Intel386™ MicroComputer Model 300SX System 
Board. 














Fy] A letter, number, symbol, or word enclosed in a double 
rectangle, and printed in small type represents a a key on your 
keyboard. For example, the instruction "press [F1]" means press 
the key labeled "F1" on your keyboard. 























Backspace This manual refers to most keys by the symbol, letter, or name 

printed on the key. The exception is the [Backspace] key. The 
Backspacel key is called Backspace to distinguish it from the left 
arrow key. 












































Enter This manual uses Enter to refer to the two [Enter] keys. Other 
manuals refer to the [Enter] keys as RETURN, CARRIAGE 
RETURN, or use an arrow. All these items are interchangeable. 
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K+ i 





Kb 


Mb 


Two or three key names with plus signs between them indicate 
multiple-key entries. For example, [Ctl] + [At] + [bel] means hold 
down the [ct] and [at] keys and press the [el] key. 


















































In signal definitions, the asterisk (*) following a signal name 
indicates an active low signal; for example, IOCHECK*. 


An H suffix to a numerical value denotes hexadecimal numbers. 
For example, OF8H means OF8 (hexadecimal). 


A K (upper case) suffix to a numerical value is used to indicate 
size in kilobytes; i.e., 7168K, 640K, etc. Note, that while a 
kilobyte is defined as 1024 bytes, the lower case k prefix used in 
other measurements indicates a quantity of 1,000. The K suffix 
is synonymous with Kbyte. See Glossary. 


A Kb suffix to a numerical value indicates size in kilobits. For 
example: 512Kb. (One kilobit is defined as 1024 bits.) 


An M (uppercase) suffix to a numerical value is used to indicate 
size in megabytes; i.e., 1M, 256M, etc. Note, however, that 
while a megabyte is defined as 1,048,576 bytes the M prefix 
used in other measurements indicates a quantity of 1,000,000. 
The M suffix is synonymous with megabyte. See Glossary. 


An Mb suffix to a numerical value indicates size in megabits. 
For example: 4Mb. (One megabit is defined as 1,048,576 bits.) 


All system messages (screen display) are shown in a non-proportional font to 
simulate the appearance of a screen display. 


An italicized word or phrase is used to represent a variable, a publication title, or 
occasionally, to lend emphasis in textual descriptions. Where shown, DOS, UNIX 
or XENIX files, path names, and directories are also italicized. 


The longer POST and Boot error and informational messages in the index are 
followed by an ellipsis (three periods). This convention is used to denote that the 
message in the index is incomplete. The portion appearing in the index is of 
sufficient length to make a unique identification. 
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Four kinds of special admonishments are used throughout the text to emphasize 
specific information. Examples of each type of admonishment are as follows: 


=> Note 
Notes are used to provide the reader with important or explanatory 
information that stands out from the rest of the text. 


© DANGER 
DANGER indicates the presence of a hazard that wil/ cause death or 
severe personal injury if the hazard is not avoided. 


@ WARNING 
WARNING indicates the presence of a hazard that can cause death or 
severe personal injury if the hazard is not avoided. 


W CAUTION 
CAUTION indicates the presence of a hazard that can or will cause minor 
personal injury or damage to hardware or software. 
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RELATED PUBLICATIONS 


xl 


Refer to the following publications for additional information relating to the 
Intel386 MicroComputer Model 300SX Board and its operating environment. 


Intel386™ MicroComputer Model 300SX System Technical Reference 
Manual (Intel order number 459940-001) 


Intel386™ MicroComputer Model 300SX User's Guide 
(Intel order number 501329-001) 


Introduction to the 80386 (Intel order number 231252-001) 


80386 Programmer's Reference Manual 
(Intel order number 230985-001) 


386™ Microprocessor Hardware Reference Manual (Intel order number 
231 732-003) 


80386 System Software Writer’s Guide 
(Intel order number 231499-001) 


Microprocessor and Peripheral Handbook (Volumes | and Il) 
(Intel order number 230843-006) 
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1.1 INTRODUCTION 


This chapter provides an overview of the 300SX board. Included in this chapter is 
a list of features, a block diagram of the board, and a description of the feature 


set. 


1.2 OVERVIEW 


The 300SX board contains the following components: 


Intel 386SX™ central processing unit (CPU) 
Intel 387SX™ numeric coprocessor 

0, 2, or 4M of random access memory 
128K of read only memory 

8237 direct memory access controllers 
8259A programmable interrupt controllers 
8254 programmable interval timer 

6818 real time clock 


Intel 8742 keyboard and mouse controller 
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e@ = Intel 82072 floppy disk controller 

e AT hard disk interface 

e Cirrus Logic VGA/EGA/CGA/Hercules/MDA video display controller 
@ Two 9-pin serial ports 

@ One 25-pin parallel port 

@ One PS/2 mouse port 

@ One 9-pin TTL video connector 

@ One 15-pin analog video connector 

e@ Four 16-bit expansion slots 

@ One parallel interface controller 


Figure 1-1 presents a functional block diagram of the 300SX board and Figure 
1-2 shows the layout of the board 
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Figure 1-1. 300SX Board Functional Block Diagram 
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Figure 1-2. 300SX Board Layout 


1-4 Intel386™ MicroComputer Model 300SX Board 


Board Overview 





1.3 


1.3.1 


1.3.2 


1.3.3 


1.3.4 


FEATURE SET DESCRIPTION 


This section gives a detailed description of the features listed earlier. 


Central Processing Unit (CPU) 


The CPU is a 32-bit 386SX microprocessor. The 386SX incorporates multitasking 
support, pipelined architecture, memory management, address translation 
caches, and a high-speed bus interface. The CPU runs at a clock speed of 

16 MHz (62.5 ns cycle time) with the system clock of 32 MHz. 


The 386SX features 32-bit internal data paths, 16-bit external data paths, and 
directly outputs a 24-bit physical address. It also has a physical memory range 
of up to 16M (the maximum amount of addressable memory on the ISA bus). 


Random Access Memory (RAM) 


The 300SX board is available with 0, 2, or 4M of dynamic random access 
memory (DRAM). 


Read Only Memory (ROM) 


The board contains 128K of ROM, which contains a ROM-resident system and 
video basic input/output system (BIOS) and a power-on self test (POST) that 
performs automatic system diagnostics. 


Direct Memory Access (DMA) Controller 


The DMA controller, contained in the 82231 portion of the Intel 82230/82231 Chip 
Set, provides seven DMA channels for data transfer between main memory and 
I/O devices (typically disks or communications channels). The 82331 contains 
two 8237 DMA controllers. 
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1.3.5 


1.3.6 


1.3.7 


1.3.8 


1.3.9 


Programmable Interrupt Controller (PIC) 
Thirteen interrupt levels are provided by the 82230 portion of the 82230/82231 


Chip Set. The 82230 includes two 8259A programmable interrupt controllers 
(PICs). 


Programmable Interval Timer (PIT) 
The 82231 portion of the 82230/82231 Chip Set provides an 8254 programmable 


interval timer (PIT). The 82231 generates timing for memory refresh, software 
timing control, and speaker frequency. 


Real-time Clock (RTC) 
The RTC, contained in the 82230 portion of the 82230/82231 Chip Set, combines 


a complete time-of-day clock with alarm, 100-year calendar, a programmable 
periodic interrupt, and 50 bytes of low power memory. 


Keyboard and Mouse Controller 


The keyboard and mouse controller supports a 101- or 102-key enhanced 
keyboard and a three-button mouse. 


Floppy Disk Controller 


The 300SX board uses an Intel 82072 for floppy disk control. The controller 
supports the following two types of floppy disk drives. 


e 1.44M or 720K 3.5-inch floppy disk drive 


@ 1.2M or 360K 5.25-inch floppy disk drive 
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1.3.11 


1.3.12 


1.3.13 


AT Fixed Disk Interface 


The 300SX board provides an interface to a fixed disk controller. The interface 
supports the following types of AT interface fixed disk drives. 


@ 40M 3.5-inch fixed disk drive 
@ 80M3.5-inch fixed disk drive 
@ 120M 3.5-inch fixed disk drive 


@ 170M 3.5-inch fixed disk drive 


Video Display Subsystem 
The video controller used on the 300SX board consists of a Cirrus Logic GD510A 
Graphics Attributes device, a Cirrus Logic GD520A Sequencer/CRT Controller 


device, and a digital-to-analog converter. The video controller provides MDA, 
CGA, EGA, VGA, extended VGA, and Hercules compatible modes. 


Serial Port 


The 300SX board is equipped with two 9-pin serial ports configured as COM1 
and COM2. 


Parallel Port 


The 300SX board provides one parallel printer port configured as either LPT1 or 
LPT2. 
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1.4 OTHER FEATURES 
e Fifty bytes of CMOS RAM and a battery backed-up power source for 
keeping system clock/calendar and system configuration parameters in 
permanent memory. 
e@ Optional 387SX numeric coprocessor 


e A keylock interface for prevention of unauthorized keyboard access 


e Four 16-bit (86/62-pin) I/O expansion slots 
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Central Processing Core 








2.1 INTRODUCTION 
This chapter describes the central processing core of the 300SX board. The 
386SX CPU, the 387SX numeric coprocessor, and the data and control buffers 


are discussed. For more detailed information on these components, refer to the 
Intel Microprocessor and Peripheral Handbook. 


2.2 ° OVERVIEW 
The central processing core contains the following components: 
e@ A 386SX 32-bit CPU 
@ A 387SX numeric coprocessor 
e@ Data and contro! buffers 


Figure 2-1 diagrams the central processing core. 
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Figure 2-1. Central Processing Core 
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2.3 


2.3.1 


2.3.2 


CPU 


The CPU is an Intel 386SX microprocessor operating at 16 MHz with a clock 
cycle time of 62.5 ns. The CPU has separate 16-bit data and 24-bit address 
paths, plus on-chip memory management and protection. The CPU supports 
multi-user multi-tasking systems, memory management, virtual memory, and task 
isolation or memory isolation. The 386SX is functionally equivalent to the 386™ 
CPU, except that the 386SX CPU has a 16-bit external data bus. 


Real Mode Architecture 


Real mode is the default mode of the CPU upon reset or power up and has the 
same base architecture as the 8086, but provides access to a 32-bit register set. 
Real mode is compatible with 8086/8088 and 80286 CPUs at the object code 
level and has the same capabilities and limitations. In real mode, addressable 
physical memory is limited to 1M via segment registers, with a 64K limitation on 
segment size. Real mode does not provide memory protection features. 


Real mode addresses are formed, as in the 8086, by combining the base 
address from a segment register with the offset value provided by the instruction. 
The CPU shifts the 16-bit base address value in the segment register left four 
bits, and adds the 16-bit offset value forming the 20-bit real address. For more 
information on real mode, refer to the Intel Microprocessor and Peripheral 
Handbook. 


Protected Mode Architecture 


Protected mode significantly increases the physical address space (to 16M) and 
allows the running of virtual memory programs of almost unlimited size (64 
terabytes). In this mode, the integrated memory management and protection 
mechanism translates virtual addresses to physical addresses. It also isolates 
the operating system and enforces protection rules necessary for maintaining 
task integrity in a multi-tasking environment. This is useful in a multi-tasking and 
multi-user environment where resources are shared. 
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2.3.3 


2.3.4 


2-4 


Protected mode provides memory paging, I/O protection, virtual-8086 mode, and 
a full 32-bit extended instruction set. Protected mode provides source code 
compatibility with the 8086/8088 and 80286 allowing direct execution of 16-bit 
applications at higher speeds. For more information on protected mode, refer to 
the Intel Microprocessor and Peripheral Handbook. 


Virtual-8086 Mode 


The virtual-8086 mode is an extension of the protected mode. Under this mode, 
the CPU provides compatibility with applications developed for the 8086/8088 
while simultaneously providing a full 32-bit, large linear address programming 
environment in its protected mode. Virtual memory allows programs to overcome 
the limitation of physical memory. 


The system divides virtual memory into many different segments. These 
segments are mapped into physical memory during virtual memory execution. 
The memory management system transfers code and data between physical 
memory and disk. For more information on virtual-8086 mode, refer to the Intel 
Microprocessor and Peripheral Handbook. 


CPU Signals 


This section defines the signal functions of the CPU. A signal name followed by 
an "I" in parentheses indicates an input signal. A signal name followed by an "O" 
in parentheses indicates an output signal. A signal name followed by "I/O" in 
parentheses indicates an input/output signal. For more detailed information on 
the CPU signal functions, refer to the Intel Microprocessor and Peripheral 
Handbook. 


CLK2 (1) 


CLK2 (system clock) provides the basic timing for the system. CLK2 is a 32-MHz 
clock divided by two inside the CPU. CLK2 generates the 16-MHz CPU clock. 
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D15:0 (I/O) 

D15:0 (data bus lines) input data during read cycles of memory and I/O. D15:0 
output data during write cycles of memory and I/O. 

A23:1 (O) 


A23:1 (address bus lines) output physical memory and I/O addresses. 


BHE* AND BLE* (O) 

BHE™* and BLE* (byte enables) indicate which data bytes of the data bus take 
part in a bus cycle. BHE* (byte high enable) applies to D15:8 and BLE* (byte 
low enable) applies to D7:0. If both BHE* and BLE* are asserted, 16 bits of data 
are being transferred. 


ADS* (O) 


ADS* (address status) indicates the initiation of a valid bus cycle. It also 
indicates valid addresses are on the bus. 


M/IO* (O) 
M/lO* (memory or I/O select) distinguishes memory access from I/O access. 


When this signal is high, a memory or halt/shutdown cycle is in progress. When 
this signal is low, an I/O or interrupt acknowledge cycle is in progress. 


D/C* (O) 


D/C* (data/control) indicates a data access cycle when high, a control cycle 
when low. 
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W/R* (O) 

W/R* (write/read) indicates a data write cycle when high, a data read cycle when 
low. 

LOCK* (O) 

LOCK* (locked bus) prevents access by an external coprocessor until the CPU 
completes a read or modifies a byte in memory. 

READY* (I) 


READY* (transfer acknowledge) indicates the current bus cycle has completed. 


HOLD (I) 

HOLD (bus hold request) indicates that some device other than the 386SX 
microprocessor requires bus mastership. 

HLDA (O) 

The CPU asserts HLDA (bus hold acknowledge) as a response to a HOLD 
request. When in the Hold Acknowledge state, the CPU tri-states its buses. 
When HOLD is no longer active, the CPU deactivates HLDA and drives the bus. 
INTR (1) 

INTR (interrupt request) requests the CPU to suspend program execution and 
service all external requests. The CPU samples the INTR line at the beginning of 


each processing cycle. INTR must be active at least two processing cycles 
before the current instruction ends. 
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NMI (I) 

NMI (non-maskable interrupt) is an edge-triggered input that causes an interrupt 
which cannot be masked by software. NMI has the highest priority of all 
interrupts, and is generally not masked by software except during system 
initialization. 

PEREQ (1) 

PEREQ (coprocessor extension operand request and acknowledge) coordinates 
data transfer between the CPU and the numeric coprocessor. PEREQ requests 
the CPU to perform a data operand transfer to the numeric coprocessor. 
BUSY* (I) 

BUSY* (coprocessor extension busy) indicates a busy condition from the 
numeric coprocessor to the CPU. The CPU program execution stops as long as 
the signal remains active. 


ERROR*% (I) 


ERROR* (coprocessor extension error) indicates an error condition of the 
numeric coprocessor to the CPU. 


RESET (1) 


RESET (system reset) clears the internal logic of the CPU. RESET initializes the 
CPU with a low-to-high transition. 
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2.3.5 Basic CPU Bus Operations 


The CPU’s bus control unit manages all bus operations. It generates the 
address, data, and command signals for the external memory and I/O 

operations, and transfers instructions to the instruction pre-fetch unit. Instructions 
are stored in a 16-byte queue while waiting for decoding and execution. 


The instruction pre-decode unit receives and decodes the instructions from the 
pre-fetch queue. It places them in the decoded instruction queue for use by the 
execution unit. 


The execution unit performs the basic processing functions. It accepts the 
decoded instructions from the instruction pre-decode unit and executes them. 

It uses the bus unit to fetch and store operands during the execution of 
instructions. The execution unit does not need to wait for the completion of a bus 
cycle before taking in a new instruction. 


The address paging unit and segmentation unit provides memory management 
and protection services for the CPU. It also translates logical addresses into 
physical addresses for use by the bus unit. A register cache in the address unit 
contains the information used for performing the various memory translation and 
protection checks for each bus cycle. 


The CPU uses a 32-MHz clock to control the bus timing. The CPU divides this 


clock by 2 to produce the internal processing clock which determines the bus 
cycles. 
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2.3.6 Pipelined Address Generation 


The CPU supports address pipelining for main memory accesses. Address 
pipelining is the option of requesting the address and the bus cycle definition of 
the next internally pending bus cycle before the current bus cycle is 
acknowledged with READY* asserted. ADS* is asserted by the CPU when the 
next address is issued, The address pipelining option is controlled on a cycle-by- 
cycle basis with the NA* input signal. For more information on pipelined address 
generation, refer to the Intel Microprocessor and Peripheral Handbook. 


2.4 NUMERIC COPROCESSOR 


An Intel 387SX numeric coprocessor is socketed on the 300SX board. The 
numeric coprocessor uses the same clock generator as the CPU and fully 
supports single, double, and extended precision operations. The 387SX is 
upward object code compatible with the 8087 and 80287 numeric coprocessors 
and completely object code compatible with the 387 numeric coprocessor. 


The 300SX board performs high speed mathematical calculations, logarithmic 
functions, and trigonometric operations using the numeric coprocessor. The 
numeric coprocessor operates in conjunction with the CPU. 


The numeric coprocessor provides the 300SX board with additional data types, 
registers, instructions, and interrupts specifically designed to facilitate high-speed 
numeric processing. The registers in the numeric coprocessor hold constants 
and temporary results generated during calculations. Numeric coprocessor 
register space can be used as a stack or as a fixed register set. 
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2.4.2 
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387SX™ Data Types 


The 387SX fully implements ANSI/IEEE 754-1985 standard for binary 
floating-point arithmetic. Table 2-1 lists the seven data types that the 387SX 
supports. 


The 387SxX directly extends the CPU instruction set. Extending the instruction set 
includes trigonometric, logarithmic, exponential, and arithmetic instructions for all 
data types. 


Table 2-1. 387SX Data Types 


Word integer 16 bits +104 
Short integer 32 bits +109 


Long integer 64 bits +4018 
Packed BCD 18 digits +1018 
Single precision 24 bits +10 438 
Double precision 53 bits +410 +308 
Extended precision 64 bits +10 +4982 





387SX™ Programming Interface 


The 387SX functions as an I/O device through the I/O ports using addresses 
8000F8H and 8000FCH for sending opcodes and operands as well as receiving 
and storing results. The CPU outputs address 8000F8H when writing a 
command or reading status and outputs address 8000FCH when writing or 
reading data. 


The CPU has two input signals for controlling data transfer to and from the 
387SX: BUSY* and PEREQ (387SX request). These input signals connect to the 
corresponding 82335 pins. 


The BUSY* signal informs the CPU that the 387SX is executing an instruction and 


cannot accept another. The CPU WAIT instruction informs the CPU to wait until 
the 387SX finishes execution. 
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The PEREQ signal indicates that the 387SX needs to transfer data to or from 
memory. Because the 387SX is never a bus owner, all input and output data 
transfers are performed by the CPU. PEREQ always goes inactive before BUSY* 
goes inactive. 


The 387SX asserts an ERROR*% signal after an instruction results in an error that 
is not masked by the 387SX control register. If an error occurs, ERROR* goes 
active before BUSY* goes inactive. As a result, the CPU receives an interrupt. If 
a higher priority task does not exist, the CPU services the interrupt. 


The 387SX detects six different conditions that may occur during instruction 
execution. If the proper execution mask is not set by the control register, the 
387SX asserts an ERROR signal. The ERROR* signal generates a hardware 
interrupt holding the 387SxX in a busy state until cleared by writing zeroes to 
address FOH. 


The power-on self-test code in the system ROM enables the hardware interrupt. It 
also sets the hardware interrupt vector pointing to a routine in ROM. This routine 
clears the latch on the BUSY* signal and transfers control to the address pointed 
to by the non-maskable interrupt (NMI) vector. The NMI interrupt handler reads 
the 387SX status and determines if the 387SX caused the NMI. If it did not, 
control passes to the original NMI interrupt handler. 


While the CPU executes numeric programs in either real or protected mode, 
interrupts report exception conditions (refer to Table 2-2). 


All communication between the CPU and the 387SxX is transparent to applications 
software. The 387SX operates whether the CPU executes instructions in 
real-address mode, protected mode, or virtual-8086 mode. The CPU handles all 
memory accesses. The 387SX operates on instructions and values passed to it 
by the CPU and is not aware of the processing mode of the CPU. 


DATA AND CONTROL BUFFERS 


Bidirectional buffers transfer control and data signals between the CPU bus and 
the AT/memory buses. Two buffers transfer CPU data (D15:0) and three buffers 
transfer CPU addresses (A23:1). Discrete logic provides buffer selection. 
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Table 2-2. Exception Conditions While Executing Numeric Programs 


Interrupt 
Number Cause of Interrupt 


An ESC instruction was encountered when EM or TS of 386SX 
control register zero (CRO) was set. EM = 1 indicates that software 
emulation of the instruction is required. When TS is set, either an 
ESC or WAIT instruction causes interrupt 7. This indicates that the 
current numeric processor extension (NPX) context may not belong 
to the current task. 


An operand of a coprocessor instruction wrapped around an 
addressing limit and spanned inaccessible addresses. The failing 
numeric instruction is not restartable; its address and data operand 
may be lost. The return address on the stack does not necessarily 
point to the failing instruction or to the following instruction. The 
interrupt can be avoided by never allowing numeric data to start 
within 108 bytes of the end of a segment. 


The first word or double word of a numeric operand is not entirely 
within the limit of its segment. The return address pushed onto the 
stack of the exception handler points at the ESC instruction that 
caused the exception, including any prefixes. The 387SX has not 
executed this instruction; the instruction pointer and data pointer 
register refer to a previous, correctly executed instruction. 


The previous numeric instruction caused an unmasked exception. 
The address of the faulty instruction and the address of its operand 
are stored in the instruction pointer and data pointer registers. Only 
ESC and WAIT instructions can cause this interrupt. The 3886SX 
return address pushed onto the stack of the exception handler 
points to a WAIT or ESC instruction (including prefixes). This 
instruction can be restarted after clearing the exception condition in 
the NPX. 
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INTRODUCTION 

This chapter describes the Intel 82335 High-Integration Interface device. An 
overview of the functions of the 82335 is presented, followed by descriptions of 
the internal functional blocks. This chapter also provides information on the 


300SX board’s dynamic random access memory (DRAM) resources. The 
chapter concludes with a description of the pin functions of the 82335. 


82335 OVERVIEW 
The Intel 82335 interfaces the 386SX microprocessor to the 387SX numeric 
coprocessor and to the Intel 82230/82231 chip set. The 82335 converts CPU 
bus cycles into 80286 compatible cycles, generates necessary clock signals, and 
provides dynamic memory control. 
The 82335 is composed of the following seven functional blocks. 

e@ Dynamic random access memory (DRAM) controller 

e Address mapper/decoder 

e@ Ready generator 


e Bus cycle translator 


e@ Numeric coprocessor interface 
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e@ Clock generator/reset synchronizer 


e Parity generator/checker 


See Figure 3-1 for a block diagram of the 82335 device. 
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Figure 3-1. 82335 Block Diagram 
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3.3 DRAM CONTROLLER 


The DRAM controller keeps track of CPU bus states and provides the necessary 
signals to address and refresh up to four 16-bit banks of Mb DRAMs. It has 
built in support for both paging and bank interleaving, and is configured for fast 
page 100 ns DRAM memory modes. 


The DRAM controller can also be configured to operate in either turbo or 
non-turbo mode. In non-turbo mode, a fixed number of bus states (six per 
memory cycle) are used for all local memory accesses. The TURBO* input must 
remain static during local memory bus cycles. 


3.3.1 DRAM Resources 


The 300SX board has 2M of RAM installed, which can be expanded to 4M. 
Single in-line memory modules (SIMMs) are used for all system RAM. 


ONBOARD RAM SIMMS 


Onboard RAM SIMMs are small boards containing nine surface-mount dynamic 
random access memory (DRAM) chips. The SIMMs are organized in a 1Mb x 9 
configuration. Each of the two SIMM sockets contain two SIMMs, for a maximum 
of four SIMMs on the system board. Refer to Appendix H for information on 
installing SIMMs. 


3.3.2 DRAM Bank Configuration 


The local DRAM system can be configured into one or two banks (2 to 4 SIMMs) 
of 1M x 16-bits each. Each 16-bit bank of memory is further divided into two 8-bit 
banks, low and high. Each 8-bit bank contains one extra bit for parity. The 
300SX board contains a standard 2M of DRAM with an additional 2M optionally 
available (4M total configuration), 
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The BIOS firmware automatically determines the amount of onboard memory 
installed and configures the 82335 accordingly. The Setup program allows you 
to configure the memory between 512K and 1M. Figure 3-2 illustrates memory 
allocation for the system. 
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Figure 3-2. 300SX Memory Address Map 
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The 82335 internally decodes the address lines A23:1 from the CPU and outputs 
multiplexed row and column addresses (MA9:0), row address strobe (RAS), 
column address strobes (CASL and CASH), and write enable (WE) signals for 
local memory accesses. Each bank has separate RAS, CASL, and CASH signals 
(see Figure 3-3). 
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Figure 3-3. 82335 to DRAM Interface 
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3.3.3 


3.3.4 


3.3.5 


3-6 


Page-Mode DRAM Operation 


A DRAM tread or write access requires a row and column address. Successive 
memory accesses to the same row address and memory page (a page-hit 
memory access) only require a new column address. During a page-hit memory 
access, RAS* is kept active, and only a new CAS* is generated. Row addresses 
are taken from the higher order address bits, providing effective page-mode 
DRAM operation during successive memory accesses to the same page. 


Page-Mode Bank Interleave Operation 


A larger page size increases the chance of a page-hit memory access. One 
page of memory is kept active per bank. In a two bank DRAM configuration, a 
maximum of two pages of memory are kept active at a time. A successive 
memory access to an active page in a different bank (a page-hit-bank-miss) 
does not require a new row address and additional wait states. This increases 
the DRAM page size by a factor of two. 


The 82335 has four built-in watch-dog timers to keep track of RAS* active time. 
Once timed out, the timer forces RAS* of the corresponding bank to be 
deactivated at the end of the memory cycle such that the maximum RAS* active 
time of the DRAM will not be violated. 


Refresh Cycle 
The 82335 generates its own DRAM refresh address with a 10-bit refresh 
counter. The counter increments by one every refresh cycle. During a refresh 


cycle, the refresh address appears on MAQ:0, followed by the activation of 
RAS(3:0)* in staggered cycles. 
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ADDRESS MAPPING/DECODING OPTIONS 


The address mapping and decoding options consist of ROM and video RAM 
shadowing, and address rolling. Selection of these options is done via 
programming of the configuration, roll compare, and address compare registers. 


Shadowing 


Shadowing refers to copying data from slow memory devices (ROM) to DRAM. 
Independent shadowing can be selected for the BIOS ROM, adapter ROM, and 
video RAM by programming the ROMEN*, ENADP™*, and ENV* bits, respectively, 
of the configuration register. Figure 3-4 is a diagram of the shadow RAM 
address map. 


BIOS ROM and adapter ROM contents must be copied to the shadow DRAM 
area before setting the lock bit in the configuration register. Once the lock bit is 
set, both DRAM areas are read only. Also, enabling video RAM shadowing and 
setting the video read only (VRO) bit in the configuration register causes this 
shadowed DRAM area to be read only. The Setup program allows you to control 
the shadowing of BIOS and onboard ROM or offboard ROM. 
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3.4.2 
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Figure 3-4. 
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Roll address mapping is a method of utilizing DRAM memory space that may not 
otherwise be accessible. By not selecting BIOS ROM, adapter ROM, or video 
RAM shadowing, addresses generated in these areas access the ROMs or video 
RAM. Any local DRAM with the same physical addresses as the ROMs or video 
RAM cannot be directly addressed. To allow access to this DRAM space, the 
82335 re-maps or rolls logical addresses above the top of the available memory 
in 128K segments. 
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There are four 128K segments of physical memory (512K total) that can be 
re-mapped. These segments are in the top half of the lowest megabyte of 
memory (see Figure 3-1). The programmed memory configuration register bits 
(ROMEN*, S640, ENADP*, and ENV*) control which segments are available for 
re-mapping. The programmed roll compare registers enable roll address 
mapping and specify the logical addresses to be re-mapped. Figure 3-5 
diagrams a memory address map illustrating roll address mapping. The Setup 
program, described in Chapter 11, allows you to control address rolling. 
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Figure 3-5. Roll Address Mapping Range 
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3.4.3 Address Mapping and DRAM Control Registers 


There are five registers in the 82335 that control the operation of the address 
mapping and DRAM control options. 


@ Memory configuration register (MCR) 
e@ Roll compare registers (RC1 and RC2) 
e Address range compare registers (CCO and CC1) 
Each register resides in the local I/O space of the 82335 and is read/write active 
until the LOCK bit is set in the memory configuration register. 
MEMORY CONFIGURATION REGISTER 
The memory configuration register (MCR), located at I/O address 22H, selects a 


number of address mapping and DRAM control options. At reset, all register bits 
are set to zero. Table 3-1 lists the MCR bit assignments. 
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Table 3-1. Memory Configuration Register Bit Assignments 


Intel386™ MicroComputer Model 300SX Board 





Enable BIOS ROM/EPROM accesses 
(OQEQOOOH-OFFFFFH) 

Disable BIOS ROM/EPROM accesses, 
shadow enabled 


Base memory size is 512K 


= Base memory size is 640K 


= 256K x 1 or 256K x 4 DRAMS installed 
= 1Mx1DRAMs installed 


= 1 memory bank installed 


2 memory banks installed 
3 memory banks installed 


= 4 memory banks installed 


256K ROM/EPROM 


= 512K ROM/EPROM 


Enable adapter ROM/EPROM accesses 
(OCOOOOH-ODFFFFH) 

Disable adapter ROM/EPROM accesses, 
shadow enabled 


Enable video RAM accesses 
(OAQO00H-OBFFFFR) 

Disable video RAM accesses, 
shadow enabled 


Video area read-write 
Video area read-only 


Enable all configuration register accesses 


= Disable all configuration register accesses 
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ROMEN* Bit 


The ROMEN* bit (bit 0) enables or disables shadowing of the BIOS ROM to the 
memory address range EQOO0H - FFFFFH. Setting the ROMEN* bit to 1 enables 
BIOS ROM shadowing. Accesses to this memory address range are from the 
DRAM. Setting the ROMEN* bit to 0 disables BIOS ROM shadowing. Accesses 
to this memory address range are from the BIOS ROM. Disabling adapter ROM 
shadowing allows this memory address range to be remapped above the top of 
the physical address space. Since onboard video ROM resides in memory 
address range 0E0000 - OEFFFFH, setting the ROMEN* bit to 1 also shadows 
onboard video ROM. 


S640 Bit 

The S640 bit (bit 3) selects the base memory size. When set to 0, the S640 bit 
indicates a base memory size of 512K. When set to 1, the S640 bit indicates a 
base memory size of 640K. 

DSIZE Bit 

The DSIZE bit (bit 4) indicates the type of DRAM installed. For the 300SX board, 
the DSIZE bit is set to 1 (1Mb x 1 DRAM installed). 

INTERL Bits 

The INTERL bits (bits 6 and 7) indicate the number of memory banks installed. 


For the 300SX board, the INTERL bits are set to 00 (one memory bank installed). 
When an additional bank of memory is installed (2M), these bits are set to 01. 
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ROMSIZE Bit 


The ROMSIZE bit (bit 8) indicates the size of the installed ROM. For the 300SX 
board, the ROMSIZE bit is set to 1 (512K-bit ROM installed). 


ENADP* Bit 


The ENADP* bit (bit 9) enables or disables shadowing of the adapter ROM to the 
memory address range OCOOOOH - ODFFFFH. Setting the ENADP* bit to 1, 
enables adapter ROM shadowing. Accesses to this memory address range are 
from the DRAM. Setting the ENADP* bit to 0, disables adapter ROM shadowing. 
Accesses to this memory address range are from the ROM. Disabling adapter 
ROM shadowing allows this memory address range to be re-mapped above the 
top of the physical address space. 


ENV* Bit 


The ENV* bit (bit 10) enables or disables shadowing of the system video RAM to 
the memory address range AOOOOH - BFFFFH. Setting the ENV* bit to 1, 
enables video RAM shadowing. Accesses to this memory address range are 
from the DRAM. Setting the ENV* bit to 0, disables video RAM shadowing. 
Accesses to this memory address range are from the video RAM. Disabling 
video RAM shadowing allows this memory address range to be re-mapped 
above the top of the physical address space. 


VRO Bit 
During video RAM shadowing, the VRO bit (bit 11) selects either read/write 
access or read only access from the video RAM area (AQ000 - BFFFFH). When 


set to 1, the VRO bit allows read only access to the video RAM area. When set to 
0, the VRO bit allows read/write access to the video RAM area. 
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LOCK Bit 

The LOCK bit (bit 15) enables or disables external access to the configuration, 
roll compare, and address range compare registers. Setting the LOCK bit to 0, 
creates the following conditions: 


e The configuration, roll compare, and address range compare registers are 
read/write active at even I/O addresses from 22H - 2BH. 


e The status outputs SO* and S1* are not generated for these even I/O 
addresses. 


@ The shadowing DRAM area is available for both reading and writing. 
Setting the LOCK bit to 1, creates the following conditions: 


e The configuration, roll compare, and address range compare registers are 
not accessible. 


e@ The status outputs SO* and S1* are generated for I/O addresses between 
22H and 2BH. 


e The shadowing DRAM area is read only with the exception of AOOOOH to 
BFFFFH if the VRO bit is cleared. 


Once the LOCK bit is set to 1, the configuration, roll compare, and address 
compare registers can only be accessed by resetting the system. 


When writing to the 82335 registers, all bits are written over. Care should be 
taken to insure that all data bits written are set for the intended operation. 
ROLL COMPARE REGISTERS 

There are two roll compare registers, RC1 and RC2, located at I/O addresses 
24H and 26H, respectively. These registers re-map logical addresses into 


physical addresses above the physical address space. Table 3-2 lists the RC1 
and RC2 bit assignments. 
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Table 3-2. Roll Compare Registers Bit Assignments 


Poe EN | Enables roll address mapping 


it 
-1 Address Mask Selects address bits to be included in re-mapping 
comparison (M23: 17) 
Compare Data Selects address range to be re-mapped (C23:17) 


In roll address mapping, the output of the roll comparator activates the address 
mapper and causes an address roll-over. This is accomplished by using the 
address bits A23:17, and the three outputs from each roll compare register: 
compare enable, address mask, and compare data. Each time the 82335 
receives a new address, it compares the address bits A23:17 with the compare 
data C23:17 using M23:17 as a mask. 









ADDRESS RANGE COMPARE REGISTERS 
There are two address range compare registers, CCO and CC1, located at I/O 
addresses 28H and 2AH, respectively. They are used to decode the onboard 


memory address range. Table 3-3 lists the CCO and CC1 bit assignments. At 
reset, CCO is enabled and CC1 is disabled. 


Table 3-3. Address Range Compare Registers Bit Assignments 


Enables address range comparison 


Address Mask Selects address bits to be included in address 
range comparison (M23: 19) 

















Intel386™ MicroComputer Model 300SX Board 3-15 


Intel 82335 High-Integration Interface Device 


3.4.4 


3-16 


The onboard memory address range is decoded in a similar manner as the 
roll-over address range. Each address range comparator accepts address 
inputs A23:19, compare data C23:19, mask data M23:19, and enable bit EN. 
Each comparator compares A23:19 with C23:19 using M23:19 as a mask. 


Chip Select Signals 


The address mapper/decoder uses the configuration, roll compare, and address 
range compare register contents along with input addresses to generate the 
following output signals: 


ROMCSO* ROM 0 chip select 

ROMCS1* ROM 1 chip select 

LMEGCS* Lower meg chip select 

OBMEM — Onboard memory address range 


The ROM chip select signals are functions of the ROMSIZE, and ROMEN* bits in 
the configuration register as well as the input address. Enabling ROM shadowing 
(ROMEN* = 1) disables the ROM chip select outputs. Disabling ROM 
shadowing activates the ROM chip select outputs as follows: 


If ROMSIZE = 0 (256K ROM) 
ROMCSO* decodes the address ranges OEO000H:EFFFFH 
and FEQOOOH:FEFFFFH. 
ROMCS1* decodes the address ranges OFOOO0H:0FFFFH 
and FFOOOOH:FFFFFFH. 


If ROMSIZE = 1 (612K ROM) 
ROMCSO0* decodes the address ranges OEQO00H:0FFFFFH 
and FEOQQOOH:FFFFFH. 
ROMCS1* is inactive. 
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The lower meg chip select output (LMEGCS) is a function of both the input 
address and M/lO* inputs. Decoding a memory address within the first 
megabyte of memory activates LMEGCS. LMEGCS is inactive during I/O cycles. 


The onboard memory output (OBMEM) is a function of the address range 
comparators, roll comparators, and the bits in the configuration register 
(ROMEN*, ROMSIZE, DSIZE, and S640). OBMEM differentiates local DRAM 
access from system RAM, ROM, or I/O accesses. During system memory 
addressing, the OBMEM output is inactive and the NA* output is deactivated to 
extend the CPU address long enough to be latched onto the system address 
bus. 


3.5 READY GENERATOR 


The 82335 indicates completion of the current bus cycle to the CPU with the 
READYSX* signal. The ready generator determines the appropriate number of 
wait states (if any) to insert and activates the READYSX* output at the correct 
time. Zero wait states occur during a page-hit bank-hit and a page-hit 
bank-miss. Two wait states occur during a page-miss bank-hit and a page-miss 
bank-miss. One wait state occurs during a new RAS cycle. 


The ready generator has three external inputs: READY286*, READYNPX*, and 
EXTRDY. The READY286* input, driven by the 82230 READY* pin, identifies the 
completion of system bus cycles. The READYNPX* input indicates the 
completion of numeric coprocessor bus cycles. The level-triggered EXTRDY 
input directly gates READYSX*. The READYSX* output is held inactive until the 
EXTRDY input is sampled active. EXTRDY extends bus cycles when using slow 
peripherals or off-board memory. Setup and hold times for these inputs must be 
met to guarantee correct operation. 
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BUS CYCLE TRANSLATOR (BCT) 


The 82335 has a built-in interface unit that translates 386SX control signals to 
80286 control signals. The bus cycle translator (BCT) identifies the bus cycle 
being performed, monitors the CPU T-states, and outputs 80286-like bus control 
signals to the 82330/82331 chip set and other components on the system board. 


As the BCT monitors control inputs from both the CPU and the 82231, it 
determines what type of cycle is being requested. The bus tracker monitors the 
timing of the bus cycle and simultaneously outputs 80286-type bus control 
signals when one of the following cycles is being requested: 


e |/O access 

e@ System memory access 

@ = Halt/shutdown 

e@ = Interrupt 
The control signals output are SO*, S1*, and M/lO286*. The SO* and S1* 
outputs are not activated for local memory accesses, or for accesses to the 
82335 device 1/O. 
In addition to controlling status output to the 82230/82231 chip set, the BCT also 
controls the hold request (HRQSX) input to the CPU. The BCT translates a hold 
request signal from the 82230 (HRQ286) into a 386SX processor-compatible 
output (HRQSX). The CPU responds with a hold acknowledge (HLDASX) to the 


82335. The 82335 translates this signal into a HLDA output to the 82230/82231 
chip set. 
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3.7 NUMERIC COPROCESSOR INTERFACE 


The 82335 automatically senses when a numeric coprocessor is installed. If a 
numeric coprocessor is not installed, REFRESH* toggles BUSYSX* and 
PEREQSxX is forced low. The numeric coprocessor interface is diagrammed in 
Figure 3-6. 


A numeric exception latches BUSYSX* low and forces PEREQSX high. This 
holds processing on the CPU until numeric coprocessor transfers are completed. 
The ERROR%* output from the numeric coprocessor becomes active, causing the 
82230 to issue an interrupt request (IRQ13). The interrupt handler performs an 
IOWR cycle to address OxFOH, clearing the BUSY latched hardware. The 
interrupt handler clears the numerics ERRORNPX signal and normal operation 
resumes. 
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Figure 3-6. | Numeric Coprocessor Interface 
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3.8 CLOCK GENERATOR/RESET SYNCHRONIZER 


The clock generator synchronizes the CPU, numeric coprocessor, and 
peripherals by converting an input frequency into system clock outputs (CLK2 
and PCLK*). A 32-MHz external oscillator, connected to the 82335 EFI pin, 
provides the input frequency. The internally buffered EFI input is output to the 
CPU and numeric coprocessor through the CLK2 output. The EFI input, divided 
by two (16 MHz), also provides the clock output (PCLK*) for the 82230/82231. 


The reset synchronizer receives the RESETCPU and SYSRESET inputs from the 
82230 and generates the synchronous outputs RESETSX and RESETNPX. When 
the SYSRESET signal is activated, both the RESETSX and RESETNPX outputs 
are asserted to reset the entire system. Activating the RESETCPU input 
generates the RESETSX output and resets the CPU. RESETCPU and SYSRESET 
are asynchronous inputs. 


3.9 PARITY GENERATOR/CHECKER 


The 82235 has a built in parity generator and checker to maintain data integrity 
for the DRAM. The parity generator/checker has data bus input/outputs D15:0, 
and two parity input/output pins, parity high byte (PARH) and parity low byte 
(PARL). The three-state PARH and PARL I/O pins directly drive the DRAMs 
without data transceivers. 


During memory write cycles, the internal parity generator evaluates the D15:0 
pins, and outputs PARH and PARL to the DRAM. During memory read cycles, 
combined DRAM data (D15:0) and parity outputs (PARH and PARL) are checked 
for parity errors. A detected parity error asserts parity error pin PERROR*. 


A parity register bit, provided within the 82335, resets the PERROR* output. Bit 2 
of the /O address 61H is the PARCHKEN (parity check enable) bit. 

Programming the PARCHKEN bit to 0 enables local DRAM parity checking. The 
register at I/O address 61H is write-only and cannot be read. 
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3.10.2 


3.10.3 


3.10.4 


3.10.5 
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82335 SIGNALS 
This section describes the signals present at the I/O pins of the 82335. A name 
followed by an "I" in parenthesis, such as ADS* (I), means the signal is an input. 


Names followed by an "O" in parenthesis, such as CLK2 (O), are outputs. Names 
followed by "I/O", such as D15:0 (I/O), are input/output signals. 


A(23:1) (I) 

A23:1 (address inputs) select the dynamic RAM address for a memory read or 
write operation. 

A20GATE (I) 

The keyboard/mouse controller uses the AZOGATE input to force A20 low. When 
A20GATE is low, A20 is forced low internal to the 82335 during CPU memory 
cycles (not DMA or master). When A20GATE is high, A20 follows the CPU 
address input from the A20 pin. 

ADS* (I) 

ADS* (address status) indicates a valid, CPU driven, bus cycle definition and 
address (W/R*, M/IO*, D/C*, BLE*, BHE*, and A23:1). 

BHE* (I) 


BHE* (byte high enable) indicates when data is being transferred on D15:8 (the 
physical address of the high byte of a 16-bit data word). 


BLE* (I) 


BLE* (byte low enable) indicates when data is being transferred on D7:0 (the 
physical address of the low byte of a 16-bit data word). 


Intel386™ MicroComputer Model 300SX Board 


Intel 82335 High-Integration Interface Device 


3.10.6 


3.10.7 


3.10.8 


3.10.9 


3.10.10 


3.10.11 


BUSYNPX* (I) 


BUSYNPx? indicates a busy numeric coprocessor. BUSYNPX* is connected 
directly to BUSY* of the numeric coprocessor. 


BUSYSX* (O) 


BUSYSX* indicates a busy numeric coprocessor. BUSYSX* is connected 
directly to BUSY* of the CPU. 


CASH(3:0)* (O) 
CASH(3:0)* (column address strobe high byte) is used by the high byte of the 


DRAM array to latch the column address present on the MA9:0 pins. 
CASH(3:0)* directly drives the DRAM array. 


CASL(3:0)* (O) 
CASL(3:0)* (column address strobe low byte) is used by the low byte of the 


DRAM array to latch the column address present on the MA9:0 pins. CASL(3:0)* 
directly drives the DRAM array. 


CLK2 (O) 

CLK2 (32 MHz) drives the CPU and numeric coprocessor input clocks. The CPU 
and the numeric coprocessor internally divide CLK2 by two. 

D/C* (I) 


D/C* (data/control select) distinguishes between data and control bus cycles. 
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3.10.13 


3.10.14 


3.10.15 


3.10.16 
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DEN* (0) 


DEN* (data enable) enables the transfer of data between the DRAM array and 
the local data bus. 


DIR (O) 


DIR (direction) controls the direction of the data transceivers. An active DIR 
indicates data is being written into memory. 


D15:0 (I/O) 


During initialization of the 82335, D15:0 (data bus) write and read control words 
to and from the internal memory configuration registers. The 82335 uses D15:0 
for parity generation and checking of data transferred between the bus and the 
DRAM array. 


EFI (I) 
EFI (external frequency in), driven by an external oscillator (82 MHz), generates 


the CLK2 and PCLK* output clocks. The EFI input also drives all internal 82335 
logic. 


ERROR‘ (1) 


The ERROR input indicates when a numeric coprocessor error has occurred. 
ERROR* connects directly to the ERROR* output of the numeric coprocessor 
and the ERROR? input of the 82230. 
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3.10.17 


3.10.18 


3.10.19 


3.10.20 


3.10.21 


3.10.22 


EXTRDY (I) 
EXTRDY (external ready) inserts additional wait states into CPU bus cycles. 


Deactivation of EXTRDY during a bus cycle delays the active edge of the 82335 
READYSX* output until the EXTRDY input is sampled active. 


FM and MMS (I) 
The FM and MMS inputs select the DRAM operating mode. FM and MMS are 


tied high, which selects the mode for fast 100 ns DRAM. This mode allows up to 
four pages to be active simultaneously. 


HLDA (O) 


HLDA (hold acknowledge) indicates the CPU has relinquished control of the local 
bus. It is asserted in response to activation of the HLDASX input from the CPU. 


HLDASX (I) 


The CPU asserts HLDASX (hold acknowledge SX) in response to the assertion of 
the CPU’s HOLD pin; indicating the CPU has relinquished control of the bus. 


HRQ286 (I) 


The 82231 drives HRQ286 (CPU hold request) when requesting DMA or refresh 
cycles. 


HRQSX (0) 


HRQSX (CPU hold request) drives the CPU's HOLD input. HRQSX is the 
HRQ286 input synchronized to CLK2. 
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3.10.23 


3.10.24 


3.10.25 


3.10.26 


3.10.27 


3.10.28 


3-26 


LMEGCS* (O) 

LMEGCS* (lower meg chip select) decodes A23:20 and M/IO* for memory 
accesses in the lowest megabyte of the 386SX address range. 

MA9:0 (O) 

MA9:0 (multiplexed address) provides the row and column addresses for CPU or 
DMA access, and row addresses for refresh access to the DRAM array. 
MEMR*¥ (I) 

MEMR* (memory read command) indicates an 82230 memory read cycle. The 
82235 uses this signal for memory control during DMA cycles. 

MEMW* (I) 


MEMW* (memory write command) indicates an 82230 memory write cycle. The 
82235 uses this signal for memory control during DMA cycles. 


M/1O* (1) 


M/lO* (memory/lO select) distinguishes between memory and I/O accesses. 


M/10286* (O) 


M/lO286* (memory I/O select 286) emulates the M/lIO* output of the 80286. The 
82230/82231 and other system peripherals use M/IO286* to distinguish memory 
access from I/O access. It also indicates halt/shutdown and interrupt 
acknowledge cycles. 
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3.10.29 


3.10.30 


3.10.31 


3.10.32 


3.10.33 


3.10.34 


NA* (O) 
NA* (next address) controls the address pipelining of the CPU. Asserting NA* 


validates the address of the next bus cycle in the T2P state of the current bus 
cycle. The 82335 asserts this signal during local DRAM bus cycles. 


OBMEM (0) 


OBMEM (onboard memory) indicates the current bus cycle is to local DRAM. 
The 82235 internally decodes the A23:1 and the M/lO* and D/C* inputs. 


PARH (I/O) 
PARH (parity high byte) is the upper byte parity bit of data on the bus (D15:8). 
For memory write cycles, the 82335 outputs the internally generated parity bit to 


the DRAM array via the PARH pin. During a memory read, the 82335 uses the 
data received at PARH to validate the upper byte of data from the DRAM array. 


PARL (I/O) 


PARL (parity low byte) is the lower byte parity bit of data on the local bus (D7:0), 
Its function is identical to the PARH pin. 


PCLK* (O) 
PCLK* (processor clock) drives the 82230 X3 pin. PCLK* is the EFI input 


(32 MHz) divide by two (16 MHz), and is equivalent to the 2X clock of an 8 MHz 
80286. 


PEREQNPX (I) 


PEREQNPxX (processor extension request NPX) indicates the numeric 
coprocessor requires a data transfer. 
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3.10.35 


3.10.36 


3.10.37 


3.10.38 


3.10.39 


3.10.40 


3-28 


PEREQSX (0) 


PEREQSX (processor extension request SX) requests the CPU to transfer data to 
or from the numeric coprocessor. 


PERROR* (O) 

PERROR% (parity error) indicates that the 82235 has detected a parity error in 
either the upper or lower byte of data from the DRAM array. 

RAS(3:0)* (O) 

RAS(3:0)* (row address strobe) is used by the DRAM array to latch the row 
address present on the MA9:0 pins. RAS(3:0)* supports up to a four-way 
interleaved DRAM configuration with page-mode access and drives the DRAM 
array directly and needs no external drivers. 

READY286* (I) 


READY286* indicates a completed I/O bus cycle. 


READYNPX* (I) 


READYNPX* indicates a completed numeric coprocessor bus cycle. 


READYSX* (O) 


READYSx* indicates a completed current bus cycle to the CPU. Its output is a 
function of the internally generated memory ready signal, and the READY286*, 
READYNPX*, EXTRDY, and TURBO* inputs. 
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3.10.42 


3.10.43 


3.10.44 


3.10.45 


3.10.46 
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REFRESH* (I) 


REFRESH* notifies the DRAM controller that the DRAM array requires refresh. 


RESETCPU (I) 


RESETCPU is activated during system power up, or when the CPU generates a 
HALT status. 


RESETNPX (0) 


RESETNPX drives the RESETIN pin of the 387SX. It is active only during system 
power up or a front-panel reset. 


RESETSX (0) 


RESETSX drives the RESET pin of the 386SX processor. RESETSX is the logical 
OR of the SYSRESET and RESETCPU inputs. 


ROMCS(1:0)* (O) 


ROMCS(1:0)* (ROM chip select) selects the ROMs during system initialization. 
Once the ROM contents are copied into the DRAM space, the ROMCS* outputs 
are disabled and the ROM addresses are mapped into the DRAM physical 
address space by the 82335. 


S(1:0)* (O) 


S(1:0)* (bus cycle status) indicates the initiation of a system bus cycle and, along 
with M/lI0286*%, defines the type of bus cycle. 
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3.10.47 


3.10.48 


3.10.49 


3.10.50 


3.10.51 


3-30 


SYSRESET (I) 


SYSRESET is driven active during system power up or a front-panel reset. 


TEST(1:0) (I) 


TEST(1:0) (test mode) is reserved for special test modes. These test inputs are 
pulled inactive during normal operations. 


TURBO* (I) 

When asserted, (turbo mode select) TURBO* allows the CPU local bus to run at 
maximum performance. Deactivating the TURBO* input causes the 82335 
READY generation logic to insert additional wait states into each bus cycle. In 


the non-turbo mode, CPU performance approximates 8 MHz 80286 bus 
efficiency. 


WE* (O) 


WE* (write enable) is used by the DRAM array to enable input for a write 
operation. WE* drives 4M of DRAM with no additional buffering. 


W/R* (1) 


W/R* (write/read select) distinguishes between read and write cycles from the 
CPU. 
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4.1 INTRODUCTION 
This chapter describes the Intel 82230/82331 Chip Set. These two devices work 
together to provide a high integration PC AT interface on the 300SX board. The 
chapter begins with an overview of the 82230/82331 Chip Set and concludes with 
a detailed description of these devices. For additional information on the 


82230/82231 Chip Set, refer to the Intel Microprocessor and Peripheral 
Handbook. 


4.2 82230/82331 OVERVIEW 


The Intel 82230/82231 is a high integration chip set (see Figures 4-1 and 4-2). 
The 82230 performs the functions of the following devices: 


e A6818 real time clock/RAM 
e@ Two Intel 8259A programmable interrupt controllers 
e Anlntel 82284 clock generator and ready interface 


@ AniIntel 82288 bus controller 
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4.3 


4-2 


The 82231 performs the functions of the following devices: 
e AnIntel 8254 programmable interval timer 
@ Two Intel 8237 direct memory access controllers 
e A74LS612 memory mapper 
e@ An Intel 8284A clock generator 


For information on the 82284, 82288, and the 8284A, refer to the Intel 
Microprocessor and Peripheral Handbook. For information on the 74LS612, refer 
to the manufacturer’s data sheet. 


6818 REAL TIME CLOCK (RTC) 


The 300SX board uses an RTC module of the 6818 as its real-time clock and 
configuration memory. The 6818 is contained in the Intel 82230 portion of the 
Intel 82230/82231 Chip Set. The RTC module combines a complete time-of-day 
clock with aiarm, 100-year calendar, a programmable periodic interrupt, and 50 
bytes of low power static random access memory (SRAM) for the user. System 
provisions allow the RTC to operate in a low power mode and protect the 
contents of both the RAM and clock during system power-up and power-down. 
The battery maintains clock and calendar information in the RAM. The system 
does not charge the battery. If the battery fails, it must be replaced. Figure 4-3 
illustrates the memory map for the RTC. 
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Figure 4-2. 82231 Block Diagram 
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4.3.1 RTC RAM I/O Operations 


The RTC sets the system time and date. The RTC updates at one-second 
intervals and automatically adjusts at the end of months and leap years. 


Writing the corresponding index address to I/O port 70H allows reading and 
writing of the 64 locations in the RTC. The RTC address register latches the 
address and points to the specified byte in the RTC. 


Values can be written to or read from all 64 bytes except for the following read 
only bytes: 


e Status registers C and D 
@ High-order bit (bit 7) of status register A 


e High-order bit (bit 7) of the seconds byte 
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Figure 4-3. |. RTC Memory Map 
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4.3.2 


Perform the following two steps when writing data into the RTC/RAM: 


1. Write the RAM address (data = 00H through 3FH) into 
I/O port address 70H. 


2. Write the data byte into I/O port 71H. 


Perform the following two steps when reading data from the RTC/RAM: 


1. Write the RAM address (data = OOH through 3FH) into 
/O port address 70H. 


2. Read the data byte from I/O port 71H. 


==> NOTE 
/O port address 70H is also an output port for the NMI mask. Data bus bit 
7 connects to the NMI mask bit and bits 0 through 5 connect to the 
RTC/RAM address lines. 


During normal operation, the RTC performs an update cycle once every second. 
Divider bits DV2:0 and the SET bit in register B determine the performance of an 
update cycle. Divider bits DV2:0 must not be cleared and the register B set bit 
must be cleared. During an update, the lower ten registers are not available to 
the CPU. The update cycle increments the clock/calendar registers and 
compares them to the alarm registers. An interrupt is issued if a match occurs 
between the two sets of registers (with enabled alarm and interrupt control bits). 


RTC Internal Addressable Locations 


The 64 addressable locations in the RTC are divided into 10 bytes containing the 
time, calendar, alarm data, four control and status bytes, and 50 general purpose 
RAM bytes (refer to Table 4-1). Table 4-1 also details the internal register/RAM 
organization of the RTC. 
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Table 4-1. Real-time Clock Address Map 


Seconds 

Seconds Alarm 

Minutes 

Minutes alarm 

Hours 

Hours alarm 

Day of week 

Date of month 

Month 

Year 

Status register A 

Status register B 

Status register C 

Status register D 

Diagnostic status byte 
Shutdown status byte 

Floppy disk drive type byte 
Intel reserved 

Fixed disk type byte 

Intel reserved 

Equipment byte 

Low base memory byte 
Requested high base memory byte 
Requested low expansion memory byte 
High expansion memory byte 
Drive C extended type byte 
Drive D extended type byte 
Intel Reserved 

Features installed 

Drive type 48 parameters 
Cache/shadow/setup 

Intel reserved 

2-byte CMOS RAM checksum 
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Table 4-1. Real-Time Clock Address Map (continued) 


Actual low expansion memory byte 
Actual high expansion memory byte 


Date century byte 

Setup information 

CPU speed 

Drive type 49 parameters 
Reserved for user 





TIME, CALENDAR, AND ALARM BYTES 


The CPU obtains time and calendar information by reading the appropriate 
locations in the RTC. Writing to these locations initializes the time, calendar, and 
alarm information. Information stored in these locations are in binary coded 
decimal (BCD) format. 


Before initializing the internal registers, the set bit in register B must be set to 1 to 
prevent RTC updates. Once set, the CPU initializes the first 10 locations in BCD 
format and the set bit is cleared. 


Once initialized and enabled, the RTC performs clock/calendar updates at a 1-Hz 
rate. During updates, the 10 bytes of time, calendar, and alarm information are 
not available for reading or writing by the CPU for 2 ms. 


Table 4-2 lists the format for the 10 clock, calendar, and alarm locations. System 
software sets the real-time clock to BCD data mode. 
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Table 4-2. Time, Calendar, and Alarm Data Format 


Seconds 00 
Seconds alarm 01 
Minutes 02 
Minute alarm 03 
Hours 04 
(12 hour mode) 01:12 (AM) 


(24 hour mode) 00:23 
Hours alarm 05 
(12 hour mode) 01:12 (AM) 
(24 hour mode) 00:23 
Day of week 06 
Date of month 07 
Month 08 
Year 09 





==> NOTE 
The RTC does not affect the 50 bytes of RAM from index address OEH to 
3FH. These bytes are accessible during the update cycle. 
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4.3.3 Status Registers 
The four control and status bytes (status registers A:D) control the operation and 
monitor the status of the RTC. These registers, located at index addresses 


OAH:0DH, are accessible by the CPU at all times (refer to Tables 4-3 through 
4-6). 


=> NOTE 
A setup program must initialize status registers A through D when setting 
the time and date. 


STATUS REGISTER A (0AH) 


Table 4-3. Status Register A (OAH) 


7 Update in progress (UIP) bit 
1 = The time update cycle in progress 
O= The current date and time accessed 


6:4 Divider selection (DV2:0) bits 
These bits control the divider/prescaler on the RTC. They 
specify the time-base frequency (in KHz) used. The system 
initializes to 010, specifying a time base of 32.768 KHz. 


3:0 Rate selection (RS3:0) bits 
These bits select the divider output frequency. The system 
initializes to 0110, which selects a 1024-Hz divider frequency 
and an interrupt rate of 976.562 ps. 
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STATUS REGISTER B (0BH) 


Table 4-4. Status Register B (OBH) 


Set update cycle (SET) bit 

1 = Abort the update cycle in progress. Set to 1 for system 
initialization. 

Q= _ Enable normal update cycle of one count per second. 

Periodic interrupt enable (PIE) bit 


This read/write bit selects an interrupt occurring at a rate specified 
by the rate and divider selection bits in register A. 


Enable the generation of periodic interrupts 


1= 
Q=_ Disable the interrupt (default) 


Alarm interrupt enable (AIE) bit 


1 = Enable the alarm interrupt 
0 = Disable the alarm interrupt (default) 


Update-ended interrupt enable (UIE) bit 


Enable the update-ended interrupt 
Disable the update-ended interrupt (default) 


1 
0 
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Table 4-4. Status Register B (OBH) (continued) 


Square wave enabled (SQWE) bit 


1 = Enable the square-wave frequency set by the rate selection 
bits in register A 
O= Disable square-wave frequency (default) 


Date mode (DM) bit 
Indicates whether the time and date calendar updates use binary or 
the BCD format. 


1 = Select binary format. 
Q= Select BCD format (default) 


24/12-hour (24/12) bit 
Determines whether 24-hour mode or 12-hour mode is set in the 
hours byte. 


1 = 24-hour mode (default) 
Q= 12-hour mode 


Daylight savings enabled (DSE) bit 


1 = Daylight savings time enabled 
0 = Daylight savings time disabled (default) 
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STATUS REGISTER C (0CH) 


Table 4-5. | Status Register C (0CH) 


IRQF (interrupt request flag) 
Set to 1 when any of the conditions cause an interrupt is true and 
the interrupt enable for that condition is true. 


PF (periodic interrupt flag) 

Set to 1 when a transition, selected by RS3:0, occurs in the divider 
chain. This bit becomes active, independent of the condition of the 
PIE control bit. The PF bit generates an interrupt and sets IROF if 


AF (alarm interrupt flag) 

Set to 1 when a match occurs between the time registers and alarm 
registers during an update cycle. This flag is independent of the 
condition of the AIE, and generates an interrupt if AIE is true. 


UF (update ended interrupt flag) 
Set to 1 when an update ends. This flag is also independent of the 
condition of the UIE, and generates an interrupt if UIE is true. 
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4.3.4 


STATUS REGISTER D (0DH) 


Table 4-6. | Status Register D (ODH) 


Function 


Valid RAM and time (VRT) bit 
This read-only bit determines the condition of the RTC internal 
battery. 


Battery operational 
A low power sense. Indicates a dead battery in the RTC. 


Configuration Registers 





The configuration bytes provide information on diagnostic status, shutdown 
status, equipment, memory, and other configuration parameters (refer to Tables 
4-7 through 4-22). 
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DIAGNOSTIC STATUS BYTE (0EH) 


Table 4-7. Diagnostic Status Byte (OEH) 
Toe [tion 
Real-time clock chip battery power status 


Power off 
Power on 


Configuration record (checksum status indicator) 


Checksum not valid 
Checksum valid 


Incorrect configuration information 
Checks the equipment byte of the configuration record when the 
system powers up. 


1 = Configuration information not valid 
0 = Configuration information valid 


Memory size comparison 


1 = Memory size different from configuration record 
0= Memory size the same as configuration record 





==> NOTE 
In order for the configuration information to be valid, power-on check 
requires at least one floppy disk drive installed (bit 0 of the equipment byte 
set to 1) and the display switch setting matches with the display controller 
installed. 
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Table 4-7. Diagnostic Status Byte (OEH) (continued) 


Initial state of drive C or fixed disk drive controller 


1 = Wrong controller or drive C. System cannot boot from drive C. 
0 = Correct controller and drive. The system boots from drive C. 


Time status indicator (post checks) 


= Time not valid 
Time valid 


SHUTDOWN STATUS BYTE (0FH) 





When the CPU resets, the shutdown status byte is set. The reset code identifies 
the type of reset and signals the system what to do after the reset. It also 
provides a method of resetting the system without losing previously stored data 
or returning the system to the real mode from protected mode. 


Table 4-8. | Shutdown Status Byte (OFH) 


Reset information 


OOH Normal system reset 

OSH = User software reset (return from protected mode) 
01H:08H = Used by hardware self-test 

OAH:FFH = Used by hardware self-test 
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FLOPPY DISK DRIVE TYPE BYTE (10H) 


Table 4-9. 


Floppy Disk Drive Type Byte (10H) 


7:4 


First floppy disk drive type 


0000 = No floppy disk drive 

0001 = 360K drive (5.25-inch) 

0010 = 1.2M high-density drive (5.25-inch) 
0011 = 720K (3.5-inch drive) 

0100 = 1.4M (3.5-inch drive) 

0101:1111 = Reserved 


Second floppy disk drive type 


0000 = No floppy disk drive 

0001 = 360K drive (5.25-inch) 

0010 = 1.2M high-density drive (5.25-inch) 
0011 = 720K (3.5-inch drive) 

0100 = 1.4M (3.5-inch drive) 

0101:1111 = Reserved 





Intel386™ MicroComputer Model 300SX Board 


Intel 82330/82331 Chip Set 





FIXED DISK TYPE BYTE (12H) 


Table 4-10. Fixed Disk Type Byte (12H) 


First fixed disk drive type (drive C) 


0000 = No fixed disk drive installed 
0001:1110 = Types 1-14 
1117 = Types 16 - 255 (refer to extended byte 19H) 


Second fixed disk drive type (drive D) 


No fixed disk drive installed 
0001:1110 = Types 1 - 14 
Types 16 - 255 (refer to extended byte 1AH) 





EQUIPMENT BYTE (14H) 


The hardware self-test uses the equipment byte. The format of the equipment 
byte is described in Table 4-11. 
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Table 4-11. Equipment Byte (14H) 


Number of floppy disk drives installed 


00 = 1 drive 
01 = 2drives 
10 = Reserved 
11 = Reserved 


Type of video display controller used 


00 = Extended functionality controller 
01 = Color graphic video display controller in 40-column mode 


10 = Color graphic video display controller in 80-column mode 
11 = Monochrome display controller 


1 = Numeric coprocessor installed 
Q= No numeric coprocessor 


Presence of floppy disk drive 


1 = Floppy disk drive installed 
0 = No floppy disk drive 
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LOW AND HIGH BASE MEMORY BYTES (15H AND 16H) 


Table 4-12. Lowand High Base Memory Bytes (15H and 16H) 


Address 15H (low-byte base size) 
Address 16H (high-byte base size) 


0100H = 256K RAM 
0200H = 512K RAM 
0280H = 640K RAM 





REQUESTED LOW AND HIGH 
MEMORY EXPANSION BYTES (17H AND 18H) 


This word indicates the total amount of expansion memory (above 1M) set by the 
system configuration program before any unused memory is rolled. 


Table 4-13. Low and High Memory Expansion Bytes (17H and 18H) 


Address 17H (low-byte expansion size) 
Address 18H (high-byte expansion size) 


0200H = 512K RAM expansion 
0400H = 1024K RAM expansion 
O600H = 153K RAM expansion 
3CO0H = 15360K RAM expansion 
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DRIVE C EXTENDED BYTE (19H) 


Table 4-14. Drive C Extended Byte (19H) 


Addresses 00H:0FH (reserved) 
Addresses 10H:FFH (types 16:255) 


DRIVE D EXTENDED BYTE (1AH) 





Table 4-15. Drive D Extended Byte (1AH) 


Addresses 00H:0FH (reserved) 
Addresses 10H:FFH (types 16:255) 


FEATURE INSTALLED BYTE (1FH) 





Table 4-16. Feature Installed Byte (1FH) 


i 
es 
a Floppy disk drive A installed 








Video display installed 
Keyboard BIOS installed 
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CMOS RAM CHECKSUM (2EH AND 2FH) 


The CMOS RAM checksum is the sum of the values from addresses 10H through 
2DH. 


Table 4-17. CMOS RAM Checksum (2EH and 2FH) 


ee 
Address 2EH (high byte of checksum) 





Address 2FH (low byte of checksum) 


FXD TYPE 48 PARAMETERS (20H - 27H) 


Table 4-18. FXD Type 48 Parameters (20H-27H) 


ee 
ee 
ee 
ae ae 
ee ee 
ee 





20H 
21H 
22H 
23H 
24H 
25H 
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SHADOW AND ENTER SETUP (28H) 


Table 4-19. Shadow and Enter Setup (28H) 


ow 








Video shadow disabled 
BIOS shadow disabled 


==> NOTE 
Video BIOS, alone, cannot be shadowed. It must be shadowed with the 
system BIOS. 





ACTUAL LOW AND HIGH 
EXTENDED MEMORY BYTES (30H AND 31H) 


The high and low expansion memory bytes represent the total extended memory 


(above 1M) determined during system power up and after any unused memory 
has been rolled. System interrupt 15H determines extended memory size. 
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Table 4-20. Low and High Extended Memory Bytes (30H and 31H) 


Address 30H (low-byte extended memory size) 
Address 31H (high-byte extended memory size) 


0200H = 512K RAM extended 
0400H = 1024K RAM extended 
O600H = 1536K RAM extended 
3CO0H = 15360K RAM extended 





DATE CENTURY BYTE (32H) 


The date century byte is the century part of the current date encoded in BCD 
format. 


Table 4-21. Date Century Byte (32H) 


BCD value for century 
(BIOS sets and reads this value) 
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SETUP INFORMATION (33H) 


Table 4-22. Setup Information (33H) 


Te [tem 
ce 








Copy of the 386 CRO ET bit (will always be 1, regardless if an 387SX 
is present or not) 


CPU SPEED (34H) 


Table 4-23. CPU Speed (34H) 


CPU speed 
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FXD TYPE 49 PARAMETERS (35H - 3CH) 


Table 4-24. FXD Type 49 Parameters (35H-3CH) 
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8259A PROGRAMMABLE 
INTERRUPT CONTROLLERS (PICS) 


The system interrupt controllers (INTC1 and INTC2) are Intel 8259A 
programmable interrupt controllers (PICs) contained in the 82230 portion of the 
Intel 82230/82231 Chip Set. INTC1 is located between addresses 20H and 21H 
and configured for master operation. INTC2 is a slave device located between 
addresses AOQH and A1H. 


INTC1 has seven prioritized interrupt levels and INTC2 has eight. The PIC 
minimizes the software and real time overhead in handling multilevel priority 
interrupts. 


The PIC functions as an overall manager in an interrupt-driven system 
environment. It accepts incoming interrupt requests from the various peripherals 
attached to the system unit. The PIC checks the interrupt requests for priority, 
determines whether the incoming request has a higher priority value than the 
current level, then sends an INT pulse to the CPU. The CPU acknowledges the 
INT request with an INTA signal. 


Configuring a variety of priority assignment modes any time during system 
operation structures the system interrupt (based on the system environment). 


Each peripheral device has a special program associated with its specific 
functional or operational requirements. The PIC, after receiving an interrupt 
request from the peripheral device special program, sends the interrupt request 
information to the CPU. This forces the program counter to the starting interrupt 
vector address. Interrupt vector addresses are stored in a table in low memory 
(locations 0 to 1024). 


Interrupt Controller Architecture 


The interrupt controller consists of an interrupt request register, cascade buffer, 
in-service register, interrupt mask register, and priority resolver. 
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4.4.2 


INTERRUPT REQUEST REGISTER 
(IRR) AND IN-SERVICE REGISTER (ISR) 


IRR and ISR handle the interrupts at the input lines. The IRR stores interrupt 
levels requesting service; the ISR stores interrupt levels currently in service. 
INTERRUPT MASK REGISTER 

Each interrupt line can be individually masked by the interrupt mask register 
(IMR). Masking an interrupt line prevents the IRR from generating an interrupt. 
Masking a higher priority input does not affect the interrupt request lines of lower 
priority. 

PRIORITY RESOLVER 

The priority resolver determines the priorities of the bits set in the IRR. The 


priority resolver, following the first INTA pulse from the CPU, selects the highest 
priority and strobes it into the corresponding bit of the ISR. 


Types of Interrupts 
The system module utilizes the following four types of interrupts: 
e Maskable interrupts 
@ Non-maskable interrupts 
e@ Hardware interrupts 
e Software interrupts 
The CPU enables or disables the maskable interrupt (INTR). Parity check logic 
within the 82231 masks the non-maskable interrupt (NMI). The NMI cannot be 


masked off within the CPU. The NMI mask register appears at I/O address port 
70H, 
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MASKABLE INTERRUPTS 


All maskable hardware interrupts to the CPU are processed by the interrupt 
controllers. These devices generate interrupts on the CPU interrupt line (INTR) 
and can be masked in the CPU with the Clear Interrupt Enable Flag (CLI) 
instruction. Any or all interrupts may be masked using the IMR; however, the 
interrupt vector of the PIC must be initialized in advance. Several interrupts are 
used by the system for onboard peripherals. 


Fifteen interrupt levels are available by cascading the two interrupt controllers in 
the 82230 (refer to Table 4-25). The slave controller signals the master to cause 
an interrupt. The base I/O addresses are: INTC1 (master) 20H and INTC2 (slave) 
AOH. 


Table 4-25. Interrupt Levels 


PIC Interrupt Interrupt 
Priority |} Number | Number Source 


Parity error detected 

Interval timer, counter O output 
Keyboard output buffer full 
Interrupt from controller 2 (cascade) 
Real-time clock 

Onboard video, software 
redirected to INT OAH (IRQ2) 
Real-time clock INT 

Reserved 

Auxiliary device 

INT from numeric coprocessor 
Fixed disk drive controller 
Reserved 

Serial communications port 2 
Serial communications port 1 
Parallel port 2 

Floppy disk drive controller 
Parallel port 1 




















MynmMasaas 










pH SH oe aH ppNNMNN)PD 


tV/O port 70H bit 7 controls the masking of the NMI signal. 
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The possibility of two or more interrupts demanding service at the same time 
exists. The PICs, after determining the priority of the interrupt requests, process 
the requests one at a time by transferring the control of the CPU to the higher 
priority service routine first. 
NON-MASKABLE INTERRUPTS 
NMI interrupts are caused by the following: 

e@ Detection of parity error during memory (DRAM) read on the system board 


e Parity errors on any 8-bit or 16-bit board pulling the IOCHCK* line low 


e@ System software generating a software interrupt to the NMI routine (BIOS 
call) 


Enable or disable the NMI interrupt by performing the following operations: 


e Clearing Mask F/F: OUT 70H, OOH. Executing this instruction enables the 
NMI. 


e Setting Mask F/F: OUT 70H, 80H. Executing this instruction disables the 
NMI. 


At power on, the NMI is disabled until system software executes the clear mask 
instruction. NMI remains enabled after the power-on self test completes. 
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Programming the PICs 


Initialization Command Words (ICWs) and Operation Command Words (OCWs) 
are used to program the operation of the PICs (refer to Table 4-26). 


Table 4-26. Interrupt Controller I/O Address and I/O Data 


Interrupt 1/O Port Write Read 
Controller Address Data Data 


INTC1 0020H 
Master 
(IRQ0-IRQ7) 









INTC2 


Slave 
(IRQ8-IRQ15) 
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INITIALIZATION COMMAND WORDS (ICWS) 


The initialization command words (ICWs) initialize the PICs after power-on. 
Before normal operation can begin, the PICs must be brought to a starting point 
by writing a sequence of four ICWs to each PIC. See Figures 4-4 and 4-5 for a 
description of the formats of ICWs. Figure 4-6 shows the initialization sequence 


of the ICWs. 


AO D7 D6 DS D4 D3 D2 D1 DO 


ICW1 





fo[o [00] 1 [itm] o [Snot] 1c4] 






1 = ICW4 Needed 
O = ICW4 Not Needed 












1 = Single 
0 = Cascade Mode 


1 = Level Triggered Mode 
O = Edge Triggered Mode 








AO D7 D6 DS D4 D3 D2 D1 DO 


ICw2 





4 AIS A14|A13/A12| A11 
T7 | 16 | TS | T4 | 13 





T7 - T3 of Interrupt 





Vector Address 


AO D7 D6 D5 D4 D3 D2 D1 DO 


ICW3 
(master [0 [57] 56] $5] s4] $3]82|1]50] 
ree) 1 = IR Input Has a Slave 


Figure 4-4, 





0 = IR Input Does Not Have 
a Slave 
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Command Word Format (ICW1, ICW2, and ICW3) 
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Icw3 AO D7 D6 D5 D4 D3 D2 D1 DO 










A8 D7 D6 DS D4 D3 D2 Di DO 





Note: Slave ID is equal 
to the corresponding 
master IR input. 





[0/X| Non Buffered Mode 
Buffered Mode/Slave 


Buffered Mode/Master 





1 = Special Fully 
Nested Mode 

O = Not Special Fully 
Nested Mode 
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Figure 4-5. Command Word Format (ICW3 and ICW4) 
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In 
Cascade 
Mode? 


No (SINGL = 1) 








Yes (SINGL = 0) 


No (ICA = 0) 






Is ICW4 
Needed? 





Yes (ICA = 1) 


ICw4 


Ready To Accept 
Interrupt Requests Pre 


Figure 4-6. Initialization Sequence Diagram 
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The initialization sequence starts by writing ICW1 with a value of 11H to I/O 
address 020H for INTC1 (I/O address OAOH for INTC2). The interrupt controller 
interprets this as the start of an initialization sequence and does the following: 

1. Resets the ICW counter to zero 

2. Selects the fixed priority mode 

3. Assigns the highest priority to IRO 

4. Clears the interrupt mask register and inservice register 

5. Sets the slave mode address to 7 

6. Disables the special mask mode 


7. Selects the interrupt request register for status read operations 


8. Resets the edge sense circuit for edge-triggered interrupt response 
mode 


The next three I/O writes to address 021H (OA1H for INTC2) loads ICW bytes 2, 3, 


and 4. See Figures 4-7 and 4-8 for the initialization formats from the power-on 
test routine. 
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OUT 020H AL AL = 11H (Master 8259A) 
OUT OAOH AL AL = 11H (Slave 8259A) 


D7 D6 DS D4 D3 D2 Di DO 


iow 


0000 0 0 0 1 

















ICW4 Required 
To Set 8086/88 
Set Cascade Mode 
Not Used 
By 8086/88 Mode 
Set Edge 
Triggered Mode 
1 During ICW1 
Not Used by 8086/88 
OUT 021H, AL AL = O8H (Master 8259A) 
OUT OA1H, AL AL = 70H (Slave 8259A) 
D7 D6 D5 D4D3 D2 D1 DO 
Icw2 
Master 0 0 0 01000 
Slave O 1 1 1 =0 
eee fee, 4 
Not Used 
BY 8086/88 Mode 
Interrupt Vector 
Table Offset 
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Figure 4-7. Power-on Formats (ICW1 and ICW2) 
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OUT 021H, AL AL = 04H (Master 8259A) 
D7 D6 DS D4 D3 D2 Di DO 


cows [57]56 [55 [s+ [59 [s2 [si [90] 


oo 9 0 0 1 0 © Slave 8259A 
Connected to IR2 
of Master 


OUTOA1H, AL AL. = O2H (Slave 8259A) 


D7 D6 DS D4 D3 D2 D1 DO 


fo | o | 0 | o [a | iD2/ 104} 100] 
1 #O 
Slave ID 


0 
fs [ee 


OUT 021H, AL AL = O1H (Master 8259A) 
OUTOA1H, AL AL._= O1H (Slave 8259A) 


D7D6DS D4 D3 D2 Di DO 


Icw4 |0| 0/0 |SFNM AEO! 


0 0 0 0 0 10) c¢] 1 
Set Assignment 
8086/88 Mode 


EO! Command 
Required by the 
Service Routine 


Not Used 
Set Non-buffer Mode 





Vee Not in Nested Mode 
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Figure 4-8. Power-on Formats (ICW3 and ICW4) 
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OPERATIONAL CONTROL WORDS (OCWS) 


The OCWs command the PICs to operate in various interrupt modes. Each PIC 
has three OCWs which can be programmed to change the configuration and to 
monitor controller operation. 


OCW1 can be written to address 021H (OA1H for INTC2) any time the controller 
is not in initialization mode. OCW2 and OCW3 are written to address 020H 
(OAOH for INTC2). Writing to address 020H (OAOH) with a 0 in bit 4 places the 
controller in operational mode and loads OCW2 (if data bit 3 = 0) or OCWS (if 
data bit 3 = 1). 


It is not necessary to execute the OCWs in sequence. The OCW is an output 


instruction defined by the software. Figures 4-9 and 4-10 diagram the OCW 
instruction sequence. 
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AO D7 D6 DS D4 D3 D2 D1 DO 


oows [1 [7] mes] wa [ms] w2 [wi] Mo 
Interrupt Mask 


1 = Mask Set 
O = Mask On 





AO D7 D6 DS D4 D3 D2 Di DO 


oowe [oy R [st Jeon] 0] 0 [2] [10] 













IR level to be 
Acted Upon 


01234567 


ero 
1 
foro 








=}/a/o4 























Rotate in Automatic EO! Mode (Clear) 
Non-specific EO| Command 

No Operation 

Specific EO! Command 

Rotate in Automatic EO! Set Mode 
Rotate on Non-specific EOl Command 
Set Priority Command 

Rotate on Specific EO! Command 
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Figure 4-9. Command Word Format (OCW1 and OCW2) 
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AO D7 D6 D5 D4 D3D2 D1 DO 


ocws [o To [esw [sei] 0 [+] [rm [as | 






Read Register Command 






























Read IR Read IS 










No Register Register 
Action on Next on Next 
RD* Pulse | RD* Pulse 








1 = Poll Command 
0 = No Poll Command 


Special Mask Mode 
|? 









0 1 


1 


= Set 
Special Special 
Mask Mask 





1 





























hs 
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Figure 4-10. Command Word Format (OCW3) 
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8254 PROGRAMMABLE INTERVAL TIMER (PIT) 


The system timer is an Intel 8254 programmable interval timer (PIT) located in the 
82231 portion of the Intel 82230/82231 Chip Set. The PIT contains three 
independent 16-bit counters counting down in binary coded decimal (BCD) or 
binary. The counters are read, written, and configured using common control 
logic. Each counter operates in one of the following six modes: 


@ Mode 0: interrupt on terminal count 

e@ Mode 1: hardware triggered one-shot 
@ Mode 2: rate generator 

e@ Mode 3: square wave generator 

e Mode 4: software triggered strobe 


e@ Mode 5: hardware triggered strobe 


Counter Description 


A common clock drives each of the three PIT counters. The clock frequency is 
1.19318 MHz, which is derived from the 14.31818 MHz crystal connected to pins 
X1 and X2 of the 82231. The output of counter 0 (IRQO) connects directly to 
IRQO of the 82230 interrupt controller module and provides the system timer 
interrupt for time-of-day, disk timeout, and other system timing functions. System 
hardware uses counter 1 to generate a dynamic random access memory 
(DRAM) refresh operation request signal. Counter 2 generates the tone for the 
system speaker. 


Each counter contains a control register, a status register, a 16-bit counting 
element (CE), a pair of 8-bit counter input latches (CIL and CIH), and a pair of 
8-bit counter output latches (COL and COH). Each counter also has a clock 
input for loading and decrementing the CE. The CE is a mode-defined GATE 
input for controlling the counter and an OUT signal. The counter mode and 
condition of CE controls the OUT signal state and function. Table 4-27 lists the 
functions of the counters, the respective gates, and the clock in/clock out signals. 
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Table 4-27. Counter Functions, Gates, and Signals 


System timer 
GATE 0C Always on 
CLKOC 1.193 MHz 
OUTOC PITIRQ IROA 


Speaker frequency 
GATE 2C ENBSPK 
CLK2C 1.193 MHz 
OUT2C Speaker signal 


1 Refresh request 
GATE 1C Always on 
CLK1C 1.193 MHz 
OUT1C Request refresh 





CONTROL AND STATUS REGISTERS 


The control register stores the mode and command information for each of the 
counters. Writing a byte to the write control word address (043H) loads the 
control register. The byte contains a pointer to the desired counter, the type of 
command, and count format information. System software uses a status register 
to monitor the counters and read back the contents of the control register. 


COUNTING ELEMENT (CE) 
The CE is a 16-bit synchronous down counter. Writing one or two bytes in the 
counter input latches loads the CE. The CE loads or decrements on the falling 


edge of the input clock. The CE contains the maximum count when loading 0 
and wraps around to FFFFH in binary operation. 
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Programming the PIT 
Programming the PIT requires writing a control word and initial counts to the three 


PIT counters at power-up. Register F receives the control word while each 
counter receives an initial count listed in Table 4-28. 


Table 4-28. Counter/Timer Address Map 


Counter 0 read/write 


Counter 1 read/write 
Counter 2 read/write 
Control register (write-only) 





CONTROL REGISTER (043H) 
Programming a counter requires writing control words to control register 043H 


(refer to Table 4-29). Control words specify the counter, command, mode, and 
numeric format (BCD or binary). Control register 043H is write-only. 
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Table 4-29. Control Register Bit Definition 


7:4 Command to be performed 

0000 = Latch counter 0 

0001 = Read/write counter 0 least significant byte only 

0010 = Read/write counter 0 most significant byte only 

0011 = Read/write counter 0 least significant byte then most 
significant byte 

0100 = Latch counter 1 

0101 = Read/write counter 1 least significant byte only 

0110 = Read/write counter 1 most significant byte only 

0141 = Read/write counter 1 least significant byte then most 
significant byte 

1000 = Latch counter 2 

1001 = Read/write counter 2 least significant byte only 

1010 = Read/write counter 2 most significant byte only 

1011 = Read/write counter 2 least significant byte then most 
significant byte 

11xx = Read-back command 


3:1 Operating mode selection 
These bits are don't care during Latch Counter command. 
000 = Mode 0 
001 =Mode 1 
x10 = Mode 2 
x11 =Mode 3 
100 =Mode 4 
101 =Mode 5 
Binary or BCD count down format 
This bit must be 0 during Read/Write command. 
0 = _ Binary (16-bit) count down 
1 = Binary-coded decimal count down (four decades) 
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Read/Write Counter Command 


The following three conventions must be observed when loading a counter using 
the read/write counter command: 


e@ Each counter control word must be written before loading the initial count. 


@ = Writing an initial count must follow the format specified in the control word. 
Load the least significant byte (LSB) only, most significant byte (MSB) only, 
or load the LSB then the MSB. 


e@ When writing the LSB and MSB, control must not be relinquished between 
modes. 


A new initial count can be written into the counter at any time after programming. 
Writing a new initial count does not require rewriting the control word as long as 
the programmed format is observed. 


When reading a counter, the following two conventions must be observed: 
@ The count must be latched. 


e@ When reading the LSB and MSB, control must not be relinquished between 
modes. 


Latch Counter Command 


When issuing a latch counter command, the counter output latches (COL and 
COH) latch the current state of the CE. COL and COH remain latched until read 
by the CPU, or until the counter is reprogrammed. Once read or reprogrammed, 
COL and COH return to the value currently in the CE. 


Latch counter commands can be issued to more than one counter before 
reading the first counter. Multiple latch counter commands issued to the same 
counter, without reading the counter, are ignored with the exception of the first 
command. 
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Read-back Command 


The read-back command checks the count value, mode, state of the OUT signal, 
and NULL count flag of the selected counters (refer to Table 4-30). Latched 
status bytes (OUT and NULL) remain until the counter is read or reprogrammed 
(refer to Table 4-31). 


Table 4-30. Read-Back Command Format 


Read-Back command specified 
11 = Specifies the READ-BACK command 


Latch CE/Status (LC and LS) 

If LS and LC = 0, status returns on the first read from the counter. 
The next one or two reads from the counter results in the count 
being returned. 


Bit 5 = 0 latches the state of the CE in COL and COH. 
Bit 4 = O latches status of selected counters into the status register. 


Counter selection (C2:C0) 


Bit 3 = 1 selects counter 2 
Bit 2 = 1 selects counter 1 
Bit 1 = 1 selects counter 0 
Bit O = O (must be zero) 
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Table 4-31. Format of a Status Byte Latched 


OUT signal state 


OUT signal 0 (low) 
OUT signal 1 (high) 


NULL count flag condition 


Counter loaded from the counter input registers, count can 
be read. 

Write to the control register or the counter, but the new value 
has not been loaded into CE. 


Byte transfer during Read/Write commands 


00 = Reserved 
= RWleast significant byte 
RW most significant byte 
= RWleast significant byte then most significant byte 


Operating mode selection 


000 =Mode 0 
001 =Mode 1 
010 =Mode 2 
011 =Mode 3 
100 =Mode 4 
101 =Mode 5 


Binary or BCD count down format 


O= _ Binary (16-bit) count down 
1 = BCD count down (four decades) 
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4.6 


4.6.1 


DIRECT MEMORY ACCESS (DMA) CONTROLLERS 


DMA is a process where data is transferred between I/O devices and memory 
without using the CPU. Intel 8237A DMA controllers within the 82231 portion of 
the Intel 82230/82231 Chip Set implement the process. 


The 300SX board utilizes two 8237A DMA controllers. Each DMA controller 
device generates the memory addresses and control signals necessary to 
transfer information. The DMA controllers are internally cascaded and provide 
four DMA channels for transfers to 8-bit peripherals (DMA1) and three channels 
for transfers to 16-bit peripherals (DMA2). 


DMA Operation 


The DMA controllers and I/O devices use the DMA request (DRQ) and DMA 
acknowledge (DACK”*) signals for handshaking. An I/O device activates the DRQ 
line when transferring a byte or a data word. The I/O device asserts the byte or 
data word on the data bus after receiving an active DACK* from the DMA 
controller. During normal operation, the DMA controller can be in an idle cycle, 
program condition, or active cycle. 


IDLE CYCLE 


The DMA controller enters the idle cycle when no I/O device requests service. 
During the idle cycle, the DMA controller samples the DRQ input pins every clock 
cycle. The DMA controller also samples the chip select (CS*) signal and 
determines if the CPU is attempting to access the DMA controller registers. If 
either situation occurs, the DMA controller exits the idle cycle. 


ACTIVE CYCLE 


The DMA controller enters the active cycle when a DMA request on a non- 
masked channel occurs. During an active cycle, the system programs the DMA 
controller to operate in one of four modes: single transfer, block transfer, 
demand transfer, or cascade. 
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Single Transfer Mode 


During single transfer mode, the DMA controller makes one transfer. After each 
transfer, the current word count decrements and the current address decrements 
or increments. A terminal count (TC) causes an autoinitialize if the channel is 
programmed and the current word count goes from zero to FFFFH. 

Autoinitialize, enabled by a bit in the mode register, restores channels to their 
original condition. 


An I/O device must hold DRQ active until a corresponding DACK* signal 
becomes active. If the I/O device holds DRQ active throughout the single 
transfer, the hold request (HRQ) signal goes inactive for one full cycle, then 
becomes active again. Another single transfer begins when the DMA controller 
receives a new HLDA. 


Block Transfer Mode 


During block transfer mode, a DRQ activates the DMA controller. DRQ remains 
active during an active DACK*. The controller continually makes block transfers 
during the service until it encounters a TC, caused by the word count going to 
FFFFH, or an external end of process (EOP*). If the DMA channel is 
programmed for autoinitialize, autoinitialization occurs at the end of the service. 


Demand Transfer Mode 


During demand transfer mode, the DMA controller continually makes demand 
transfers until it encounters a TC, an external EOP*, or when the current DRQ 
goes inactive. An inactive DRQ, before the last working state of the cycle, 
prevents another transfer. Current address and current word count registers 
store intermediate values of addresses and word counts between transfers. An 
EOP* causes an autoinitialize at the end of the DMA controller service. 
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4.6.2 


Cascade Mode 


During cascade mode, both DMA controllers are cascaded together for system 
expansion. The HRQ and HLDA signals, from the slave DMA controller, connect 
to aDRQ and DACK*% signal of the master DMA controller. This allows the 
master DMA controller to request the slave DMA controller to propagate through 
the priority network circuitry of the preceding device (master DMA controller). 
The cascade channel of the master controller prioritizes the slave controller and 
does not output any address or control signals of its own. The DMA controller 
responds only to DRQ and DACk®*. All other outputs, except HRQ, are disabled. 


Transfer Types 


Each of the four transfer modes performs three types of transfers: read, write, 
and verify (see Figure 4-11). 


|  §2 | S3 | sw S4 


DMA CLK(4 MHz) 





BUSALE (High During DMA) 
DACK* \, 











ADDRESSES 





MEMR* \ 








IORC* \ 








Mi 


lIOWC*/MEMW* 
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Figure 4-11. DMA Timing 
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4.6.3 


4-52 


READ TRANSFER 

Read transfers move data from memory to an I/O device by generating the 
memory address and asserting MEMR* and IOWC* during the same cycle. 
WRITE TRANSFER 

Write transfers move data from an I/O device to memory by generating the 
memory address and asserting MEMW* and IORC* during the same cycle. 
VERIFY TRANSFER 

Verify transfer is a pseudo-transfer used for diagnostics. In this type of transfer, 
the DMA operates as if it were performing a read or write transfer by generating 


HRQ, address, and DACK*. However, memory and I/O control lines remain 
inactive. 


DMA Channels 


DMA1 supports channels 3:0 and DMA2 supports channels 7:5. Both DMA 
controllers support seven channels (refer to Table 4-32). Channel zero has the 
highest priority and channel seven the lowest. 


Table 4-32. DMA Channel Assignment 


Spare 
Spare 


Floppy disk drive 
Spare 
Spare 
Spare 
Spare 
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4.6.4 


4.6.5 


The DMA controller and page register provides 24 bits of address. The system 
assigns a page register to each DMA channel. The page register supplies the 
upper eight bits of each 24-bit address. The DMA controller supplies the lower 
16 bits of each 24-bit address. Generated addresses do not cross page 
boundaries (64K for channels 3:0 and 128K for channels 7:5). 


The DMA controller and page register must be initialized before initiating a DMA 
transfer. Initialization consists of loading the starting address, the number of 
bytes, and the direction of transfer. The CPU reads and writes the DMA 
controllers’ internal registers when the controller is selected and while the CPU 
controls the bus. All registers, including those not used, are written to at 
power-up. 


Programming the DMA Controllers 


The DMA controllers can be programmed any time during an inactive HLDA. The 
CPU ensures no DMA activity occurs on the channel being programmed. To 
prevent a conflict, disable the DMA controller or mask the DMA channel before 
programming any registers. Disabling external interrupts protects the sections of 
code that set up the registers. This prevents another routine from changing the 
state of the circuit. 


DMA Internal Registers 


The DMA internal registers control DMA transfers. Table 4-33 lists all DMA 
internal registers and their size. 
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Table 4-33. DMA Internal Registers 


es ee 


Base address registers 
Base word count registers 
Current address registers 
Current word count registers 
Temporary address register 


Temporary word count register 
Status register 

Command register 

Temporary register 

Mode registers 

Mask register 

Request register 


a se fps ones ua fh AA AL 





ADDRESS AND COUNT REGISTERS 


The address and count registers specify the address and length of the transfer. 
These registers are 16 bits, requiring two successive read or write operations. 
The byte pointer flip-flop must be cleared before accessing these registers. This 
guarantees that the first operation transfers the low order byte and the second 
operation transfers the high order byte. After clearing the byte pointer flip-flop, 
control must not be relinquished by the program until both bytes are written or 
read. Table 4-34 lists the I/O port address assignments for the DMA address 
and count registers. 
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Table 4-34. I/O Port Addresses for DMA Address and Count Registers 


1V/O Address Command Codes 


DMA1 Channel 0 base and current address 
Channel 0 base and current word count 
Channel 1 base and current address 
Channel 1 base and current word count 
Channel 2 base and current address 
Channel 2 base and current word count 
Channel 3 base and current address 
Channel 3 base and current word count 





DMA2 Channel 4 base and current address 
Channel 4 base and current word count 
Channel 5 base and current address 
Channel 5 base and current word count 
Channel 6 base and current address 
Channel 6 base and current word count 
Channel 7 base and current address 
Channel 7 base and current word count 


Current Address Register 


Each DMA channel has a 16-bit current address register for storing the value of 
the address used during DMA transfers. The address automatically increments 
or decrements after each transfer and the intermediate values of the address are 
stored in the register during the transfer. The CPU reads or writes the register in 
successive 8-bit bytes while in the program state. During autoinitialize, the 
original values of the current address register are automatically restored from the 
base count register after EOP* goes active. An I/O device or TC generates 
EOP*. 
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Current Word Count Register 


Each DMA channel has a 16-bit current word count register for determining the 
number of transfers performed. The actual number of transfers is one more than 
the number programmed in the register (e.g., programming a count of 25 results 
in 26 transfers). The register loads or reads in successive 8-bit bytes by the CPU 
in the program condition. The word count decrements after each transfer until 
the value in the register goes from zero to FFFFH. At FFFFH the TC generates 
an autoinitialize. During autoinitialize, the original values of the current address 
register are automatically restored from the base count register after EOP* goes 
active. An|/O device or TC generates EOP*. 


Base Address and Base Word Count Registers 


Each DMA channel has a pair of base address and base word count registers. 
These 16-bit registers store the original value of their associated current registers. 
During autoinitialize, these values restore the current registers to their original 
values. The base registers are automatically loaded when corresponding current 
registers are written. The base registers cannot be read by the CPU. 


PAGE REGISTERS 


The system assigns each channel an 8-bit page register. These page registers 
extend the 16-bit DMA controller address space to 24 bits (refer to Table 4-35). 
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Table 4-35. Page Register Addresses for Each Channel 


YO Address Function (In/Out) 


8-bit DMA channel 2 (DACK2*) 
8-bit DMA channel 3 (DACK3*) 
8-bit DMA channel 1 (DACK1*) 


8-bit DMA channel 0 (DACKO*) 
16-bit DMA channel 6 (DACK6*) 
16-bit DMA channel 7 (DACK7*) 
16-bit DMA channel 5 (DACK5*) 
Refresh cycle page register 





PROGRAM CONTROL REGISTERS 


Program control registers program DMA transfer operations. Table 4-36 lists the 
I/O port addresses for the control registers. 
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Table 4-36. Control Registers I/O Port Addresses 


Address 
DMA1 DMA2 Operation Command Codes 


Read status register 
Write command register 
Write request register 


Write single mask register bit 
Write mode register 

Clear byte pointer flip-flop 
Read temporary register 
Master clear 

Clear mask register 

Write all mask register bits 





COMMAND REGISTER 


The 8-bit command register (refer to Table 4-37) controls the overall operation of 
the DMA subsystem. The CPU programs the command register during a 
program condition. A reset or a master clear instruction clears the command 
register. 


MODE REGISTER 
Each DMA channel has an associated 6-bit mode register (refer to Table 4-38). 
The mode registers specify the channel operating mode. When the CPU writes 


to a mode register during a program state, bits 0 and 1 specify the channel 
selected. 
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Table 4-37. Command Register Bit Assignments 


Function 


DACK* sense bit 


DACK* sense active high 
DACK* sense active low (default) 


DRQ sense bit 


1= DRQ sense active low 
0= DRQ sense active high (default) 


Extended write bit 


1= Extended write selection 
Q= Late write selection 


Rotating priority bit 


Rotating priority scheme is used 
Fixed priority used (default) 


Compressed timing bit 


1 = Compressed timing enabled 
0 = Normal timing used (default) 
Controller enable bit 


Controller disabled 
Controller enabled 


Channel address hold enable bit 


Channel 0 address hold enabled 
Channel 0 address hold disabled (default) 


Memory-to-memory enable bit 


Memory-to-memory enabled for Channel 0 and Channel 1 
Memory-to-memory disabled (default) 


0 
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Table 4-38. Mode Register Bit Assignments 


Mode selection bits 


00 = Demand mode selected 
01 = Single mode selected 
10 = Block mode selected 
11 = Cascade mode selected 


Address increment/decrement bit 


1 = Address decrement selected 
Q= Address increment selected 
Autoinitialization enable bit 


Autoinitialization enabled 
Autoinitialization disabled 


1 
0 


Transfer bits 


00 = Verify transfer 
01 = Write transfer 
10 = Read transfer 
11 = Illegal 


Channel select bits 


00 = Select Channel 0 
01 = Select Channel 1 
10 = Select Channel 2 
11 = Select Channel 3 
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REQUEST REGISTER 


Each DMA channel has an associated 4-bit request register. The system 
software sets or resets each request register bit separately. A TC or EOP* clears 
each request register bit. A system reset clears the entire request register. The 
DMA channel must be in the block transfer mode and the appropriate registers 
must be set before initiating this request. Table 4-39 lists the format for writing 
the request register. 


Table 4-39. Request Register Update 


Zs 
2 Set/reset request bit 
1= Set request bit 
O= Reset request bit 


Channel selection bits 


00 = Select channel 0 
01 = Select channel 1 
10 = Select channel 2 
11 = Select channel 3 
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4-62 





MASK REGISTER 


Each DMA channel has an associated mask bit. The mask bit disables incoming 
DRQs. Each mask bit is set when the associated DMA channel activates EOP* 
(if autoinitialize is not programmed in the DMA channel). The system software 
sets or clears each mask register bit separately. A system reset masks all DMA 
channels and disables all DMA requests. 


Two commands are associated with the mask register: Write Single Mask Bit and 
Write All Mask Bits. Tables 4-40 and 4-41 list the bit positions for both 
commands. 


Table 4-40. Write Single Mask Bit Assignments 












2 Set/reset mask bit 









{= 
Ox 


Set mask bit 
Reset mask bit 





Select channel mask bits 







00 = Select channel 0 mask bit 
01 = Select channel 1 mask bit 
10 = Select channel 2 mask bit 
11 = Select channel 3 mask bit 
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Table 4-41. Write All Mask Bit Assignments 


Set/reset channel 3 mask bit 




















Set channel 3 mask bit 
Reset channel 3 mask bit 





O= 


Set/reset channel 2 mask bit 














{c= 
O& 


Set channel 2 mask bit 
Reset channel 2 mask bit 





Set/reset channel 1 mask bit 





Set channel 1 mask bit 
Reset channel 1 mask bit 


Set/reset channel 0 mask bit 





Set channel 0 mask bit 
Reset channel 0 mask bit 





STATUS REGISTER 


The status register contains the status of the DMA controller at the time of 
readout. The status information tells which channel has reached the terminal 
count and which channel has a DMA request pending. Bits 3:0 are set every 
time the corresponding channel reaches the terminal count or when a DMA 
channel activates EOP*. Reading or resetting the status register clears the 
status register bits. Status register bits 7:4 are set when the corresponding DMA 
channel requests service. Table 4-42 lists the status register bit positions. 
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Table 4-42. Status Register Bit Assignments 


Channel 3 DMA request bit 


= Channel 3 DMA requested 


1 
0 No DMA request 


Channel 2 DMA request bit 


1 = Channel 2 DMA requested 
O= NoDMA request 


Channel 1 DMA request bit 


Channel 1 DMA requested 
No DMA request 


Channel 0 DMA request bit 


Channel 0 DMA requested 
No DMA request 


Channel 3 TC reached bit 


1 = Channel 3 DMA process completed 
0= _ Status register is read or reset 


Channel 2 TC reached bit 


Channel 2 DMA process completed 
Status register is read or reset 


Channel 1 TC reached bit 


Channel 1 DMA process completed 
Status register is read or reset 


Channel 0 TC reached bit 


Channel 0 DMA process completed 
Status register is read or reset 
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TEMPORARY REGISTER 


The temporary register is used to hold data during memory-to-memory transfers. 
Following completion of the transfers, the last word moved can be read by the 
CPU in the program condition. The temporary register always contains the last 
byte transferred in the previous memory-to-memory operation, unless cleared by 
a reset. 


NON-REGISTER PROGRAM CONTROLS 


Performing an output to the addresses specified in the program control register 
I/O executes special software commands. These commands do not depend on 
any specific bit pattern on the data bus. The three software commands are: clear 
byte pointer flip-flop, master clear, and clear request mask register. 


Clear Byte Pointer Flip-flop 

The clear byte pointer flip-flop command resets (clears) the byte pointer flip-flop 
so the next CPU access to the register contents addresses the low byte. This 
command must be executed before writing or reading new address or word 
count information. 

Master Clear 

This master clear command resets the DMA controller and has the same effect 
as a hardware reset. During a master clear, the command, status, request, 


temporary, and internal first/last flip-flop registers reset (clear) and the mask 
register sets. The DMA controller enters the idle condition after a master clear. 


Clear Request Mask Register 


The clear request mask register command resets (clears) the mask bits of all four 
DMA channels. 
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5.1 INTRODUCTION 


This chapter provides reference data for the two RS-232C serial communication 
ports and one parallel printer port on the 300SX board. Included are all 
addresses and interrupt levels. 


5.2 SERIAL COMMUNICATION PORTS 


The 300SX board provides two RS-232C serial communication ports (COM1 and 
COM2). Each port operates in an asynchronous mode for system software 
compatibility. An 82C605 multifunction communications controller provides the 
interface between the communication ports and the CPU. Refer to Table 5-1 for 
selection of port addresses and interrupt levels. Figure 5-1 shows an internal 
block diagram of the 82C605. 


Table 5-1. Selection of Addresses and Interrupt Levels 


Designation Address Interrupt 


COM1 3F8-3FFH IRQ4 
COM2 2F8-2FFH IRQ3 
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Figure 5-1. 82C605 Internal Block Diagram 


5.2.1 Connectors and Pinouts 


Connectors J2A, J2B, and J13 provide signals for COM1 and COM2. COM1 
signals connect to a DB9 RS-232 connector at J2B. COM2 signals connect to a 
DB9 RS-232 connector at J2A. Both COM1 and COM2 signals are available at 
J13 for use with ribbon cable connectors. Refer to Chapter 10 for pinout 
information on the serial I/O connectors. 
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5.2.2 


Communication Port Registers 


Access to the communication port registers is determined by multiplexed 
address bits SAD2:0 and the divisor register address (DRA) bit. COM1 and 
COM2 each contain one set of the registers listed in Table 5-2. 


Table 5-2. Serial Communication Port Register Selection 


Receive buffer (read) 
Transmit buffer (write) 
Interrupt flag (read) 
Interrupt enable 

Byte format 

Modem control 

Line status 

Modem status 
Scratchpad 
Divisor (LSB) 
Divisor. (MSB) 


SAD2 SAD1 SADO 















—a aA xX KKK OCOCO 


oo--+++$-00000 A 
-~O-0-0+-+000 A 





oo+-++00;-0-+00 A 





RECEIVE BUFFER REGISTER (RBR) 


The RBR holds the incoming data byte. Bit 0 is the least significant bit, and is 
transmitted and received first. An additional shift register assembles the 
incoming byte before loading it into the RBR. 


TRANSMIT BUFFER REGISTER (TBR) 
The TBR holds the data byte to be sent. Bit 0 is the least significant bit, and is 


transmitted and received first. An additional shift register shifts the outgoing byte 
to the TDX pin. 
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INTERRUPT ENABLE REGISTER (IER) 


The low order four bits of the IER control the enabling of each of the four possible 
types of interrupts (refer to Table 5-3). Setting the corresponding bit to 1 enables 
an interrupt. The interrupt flag register contents are not valid when all the 
interrupts are disabled. 


Table 5-3. Interrupt Enable Register Bit Assignments 


1 = Generate an interrupt when the receive buffer contains valid data 
0 = Disabled 


= Generate an interrupt when the transmit buffer is empty 
= Disabled 


Generate an interrupt when an error (overrun, parity, framing, or 
break) has been encountered. The status register must be read 
to determine the type of error. 

Disabled 


Generate an interrupt when one of the bits in the modem 
status register changes state. 


QO These four bits are set to 0. 
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INTERRUPT FLAG REGISTER (IFR) 


When accessed, the IFR bits report and record the highest pending interrupt 
(refer to Table 5-4). The following four levels of prioritized interrupts are used: 


e Line status (highest priority) 
e@ Receive buffer full 
e@ Transmit buffer empty 


e@ Modem status (lowest priority) 


Table 5-4. Interrupt Flag Register Bit Assignments 


0 = Indicates an interrupt is pending and bits 1 and 2 can be read 
to determine the source of the interrupt 
1 = Indicates no interrupts are pending 


1-1 = Line status interrupt 

0-1 = Receive buffer full interrupt 

1-0 = Transmit buffer empty interrupt 
0-0 = Modem status interrupt 
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BYTE FORMAT REGISTER (BFR) 


The read/write BFR contains format information for the serial line. 


Word Length (WL) Bits 


The WL bits (bit 0 and 1) specify the word length for received and transmitted 
characters (refer to Table 5-5). Start, stop, and parity bits are not included in the 
word length value. 


Table 5-5. Word Length Bit Assignments 


Bit1 Word Length 


0 0 
0 1 
1 0 
1 1 


Stop (SP) Bit 





The combination of the SP bit (bit 2) and the WL bits determines the number of 
stop bits used with each transmitted character (refer to Table 5-6). The receiver 
ignores additional stop bits beyond the first one, regardless of the number of 
stop bits transmitted. 


Table 5-6. Stop Bits per Transmitted Character 


| pita | Word Length Number of Stop Bits 
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Parity Generator (PG) Bit 

The PG bit (bit 3) enables parity generation (during transmission) and checking 
(during receipt). The parity bit is always after the last data bit but before the first 
stop bit. Setting the PG bit to 1, generates a parity bit of the proper state (0 or 1). 
The sum (carry ignored) of all data bits, plus the parity bit, produces either an 
even (even parity) or odd (odd parity) value. 

Even Parity (EP) Bit 

The EP bit (bit 4) controls parity sense. When set to 1, the EP bit indicates even 
parity. Transmitting an odd number of logic 1’s generates a parity error. When 
set to 0, the EP bit indicates odd parity. Unless it is set to 1, the EP bit is ignored. 
Force Parity (FP) Bit 

The FP bit (bit 5) ensures that the parity bit and sense (even or odd) match 
regardless of the sum normally used to determine parity. 

Break Bit 

Setting the break bit (bit 6) to 1, forces the transmitted data output pin to a 
spacing or logic 0 condition. Setting the break bit to 0, terminates the break 
condition. 


Divisor Register Address (DRA) Bit 


Setting the DRA bit (bit 7) to 1, permits access to the divisor registers. Setting 
the DRA bit to 0, allows access to all other internal registers. 
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MODEM CONTROL REGISTER (MCR) 


The byte-wide MCR manages the connection to an external modem or data set. 
Table 5-7 lists the bit assignments. 


Table 5-7. Modem Control Register Bit Assignments 


Function 


Force DTR* to its active state 
Force DTR* to its inactive state 


Force RTS* to its active state 
Force RTS* to its inactive state 


1 
O= 
2 Force the RI* bit (bit 6) of the MSR active when the serial port 
is in a loopback mode 


Force the RI* bit inactive 
Force the DCD* bit (bit 7) of the MSR active when the serial 


port is in a loopback mode 
0= _ Force the DCD* bit inactive 


4 Used for self-diagnostic purposes 
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LINE STATUS REGISTER (LSR) 

The byte-wide LSR (read-only) supplies serial link status information to the CPU. 
One of the conditions flagged by bits 1 through 4 of the LSR generates a line 
status interrupt. 

Receive Buffer Full (RBF) Bit 

When set to 1, the RBF bit (bit 0) indicates an incoming character has been 
transferred from the receive shift register to the receive buffer. Reading the 
receive buffer clears the RBF bit. 

Overrun Error (OE) Bit 

When set to 1, the OE bit (bit 1) indicates a new character was transferred into 
the receive buffer before the previously received character was read by the CPU. 
The previously received character is lost. Reading the LSR clears the OE bit. 
Parity Error (PE) Bit 

When set to 1, the PE bit (bit 2) indicates a parity error was detected (received 
character has a parity other than that selected). Reading the LSR clears the PE 
bit. 

Framing Error (FE) Bit 

When set to 1, the FE bit (bit 3) indicates an incoming character has no stop bit 


after the last data bit or (if parity is enabled) after the parity bit. Reading the LSR 
clears the FE bit. 
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Break Interrupt (BI) Bit 


When set to 1, the BI bit (bit 4) indicates a space condition (logic 0) is present on 
the corresponding RXD (RXD2 or RXD1) line for an entire character time. A 
character time equals a start bit time, data bit times, parity bit time, and stop bit 
time. Reading the LSR clears the BI bit. 


Transmit Buffer Empty (TBE) Bit 


When set to 1, the TBE bit (bit 5) indicates an outgoing character is loaded from 
the transmit buffer into the transmit shift register. If the TBE bit is set (bit one of 
the IER), an interrupt occurs. Writing a character to the transmit buffer clears the 
TBE bit. 


Transmitter Empty (TEMT) Bit 

When set to 1, the TEMT bit (bit 6) indicates the transmit buffer and the transmit 
shift register are both empty. If a character is present in either the transmit buffer 
or the transmit shift register, the TEMT bit is cleared. 

MODEM STATUS REGISTER (MSR) 

The byte-wide MSR holds the current value of the MODEM control lines. Each 
time one of MODEM control lines changes state, the MSR sets the corresponding 
bit to a 1. Reading the MSR clears the previously set bits. When set to 1, bits 0, 
1, 2, and 3 generate an interrupt, provided the corresponding interrupt bit is 
enabled. 


Clear to Send Changed (CSC) Bit 


When set to 1, the CSC bit (bit 0) indicates the corresponding CTS* line (CTS2* 
or CTS1*) changed state since the last time the MSR was read. 
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Data Set Ready Changed (DSRC) Bit 

When set to 1, the DSRC (bit 1) indicates the corresponding DSR* line (DSR2* or 
DSR1*) changed state since the last time the MSR was read. 

Rising Edge of Ring Indicator (RERI) Bit 

When set to 1, the RERI bit (bit 2) indicates the corresponding RI* line (RI2* or 
Rl1*) changed state since the last time the MSR was read. 

Data Carrier Detect Changed (DCD) Bit 

When set to 1, the DCD bit (bit 3) indicates the corresponding DCD* line (DCD2* 
or DCD1*) changed state since the last time the MSR was read. 

Clear to Send (CS) Bit 

The CS bit (bit 4) is the complement of the corresponding CTS* line. When in the 
diagnostic loopback mode, the CS bit is identical to the RTS bit in the MCR. 
Data Set Ready (DS) Bit 

The DS bit (bit 5) is the complement of the corresponding RI* line. When in the 
diagnostic loopback mode, the DS bit is identical to the DTR bit in the MCR. 
Ring Indicator (RI) Bit 


The RI bit (bit 6) is the complement of the corresponding DSR% line. In diagnostic 
loopback mode, the RI bit is controlled by bit 2 of the MCR. 
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Data Carrier Detect (DRD) Bit 


The DRD bit (bit 7) is the complement of the corresponding DCD* line. In 
diagnostic loopback mode, the DRD bit is controlled by bit 3 of the MCR. 


DIVISOR REGISTERS (LSB AND MSB) 


The two Divisor registers, Divisor register LSB (DRL) and Divisor register MSB 
(DRM), contain a 16-bit divisor used to generate the baud rate of the serial ports 
from the 300SX board's 1.8432 MHz crystal. DRL holds the least-significant byte 
and DRM holds the most-significant byte of the divisor. 


Table 5-8 details the contents of the Divisor registers for various baud rates. All 
values in Table 5-8 are decimal. 


Table 5-8. Divisor Register Values for Various Baud Rates 
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5.3 


5.3.1 


5.3.2 


PARALLEL PORT 


The 300SX board is equipped with one parallel printer port, configurable as either 
LPT1 or LPT2. The parallel printer port, at connector J1, provides a one-way 
interface to a printer. The parallel port is also available at connector J11 (if 
installed) for use with ribbon cable connectors. Refer to Chapter 10 for pinout 
information on the parallel printer port connectors. 


Data Latch Register (DLR) 


The read/write DLR is located at on offset of zero from the base address of the 
parallel port. Data written to the DLR is transmitted to the printer. 


Printer Status Register (PSR) 


The read-only PSR is located at on offset of 1H from the base address of the 
parallel port. Bits 2-0 of the PSR are reserved. 


BUSY BIT 


The busy bit (bit 7) reflects the state of the BUSY* input pin. When set to 0, the 
busy bit indicates that the printer is busy and cannot accept data. When set to 1, 
the busy bit indicates that the printer is ready to accept data. 


ACKNOWLEDGE (ACK) BIT 


The ACK bit (bit 6) reflects the state of the ACK input pin. When set to 0, the 
ACK bit indicates the printer received a character and is ready to accept another. 
When set to 1, the ACK bit indicates the printer is still reading the last character 
sent. 
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PAPER EMPTY (PE) BIT 


The PE bit (bit 5) reflects the state of the PE* input pin. When set to 1, the PE bit 
indicates there is no paper in the printer. When set to 0, the PE bit indicates the 
presence of paper. 


SLCT (SO) BIT 

The SO bit (bit 4) reflects the state of the SLCT* input pin. When set to 1, the SO 
bit indicates the printer is online. When set to 0, the SO bit indicates the printer is 
not selected. 

ERROR (ER) BIT 

The ER bit (bit 3) reflects the inverted state of the ERROR input pin. When set to 


0, the ER bit indicates an error condition has been detected. When set to 1, the 
ER bit indicates no errors have been detected. 
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5.3.3 Printer Controls Register (PCR) 
The read/write PCR is located at an offset of 2H from the base address of the 
parallel port. Bits 7-5 of the PCR are reserved and reset to 0. 
IRQ ENABLE (IE) BIT 
The IE bit (bit 4) enables or disables interrupts resulting from the printer ACK 
signal. Setting the IEB to 1, enables interrupts. A deasserted ACK by the printer, 
interrupts the CPU on the IRQ line specified in the configuration RAM. 
SLCTIN (SI) BIT 
The SI bit (bit 3) drives the SLCTIN output pin. Setting the SI bit to 1, selects the 
printer. 
INIT (IN*) BIT 
The IN* bit (bit 2) controls the INIT output pin. Setting the IN* bit to 0, starts the 
printer. 
AUTO FEED (AF) BIT 
The AF bit controls the AUTOFD output pin. Setting the AF bit to 1, causes the 
printer to line feed after each printed line. 
STROBE (ST) BIT 


The ST bit controls the STROBE output pin. Setting the ST bit to 1, generates an 
active high pulse (0.5 us pulse minimum) which clocks data into the printer. 
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6.1 INTRODUCTION 


The 300SX board supports a 101- or 102-key enhanced keyboard and a three 
button mouse. An Intel 8742 microcontroller controls the keyboard and mouse 
system interface (see Figure 6-1). This chapter describes the keyboard and 
mouse interface through the 8742 microcontroller. 


6.2 KEYBOARD AND MOUSE 
CONTROLLER SYSTEM INTERFACE 
The keyboard and mouse controller communicates with the system through an 
8-bit read-only status register at /O address 64H, a read only output buffer at I/O 


address 60H, and an input buffer. The input buffer consists of two parts: a data 
byte and a command byte written at addresses 60H and 64H, respectively. 
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Figure 6-1. Keyboard/Mouse Controller 


Status Register 


The controller status register (refer to Table 6-1) contains information about the 
state of the controller and system interface. 
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Table 6-1. Status Register Bit Definition 

Output Buffer (I/O Address 60H) Full 
No data from the keyboard in the output buffer (DBBOUT) 
The keyboard controller loaded the output buffer with data. 
This bit is set to O when the CPU reads it (DBBIN). 

Input Buffer (I/O Address 60H) Full 

O0= No data from the CPU in the input buffer 

1 = Data from the CPU in the input buffer. This bit is set to 0 
when the keyboard controller reads the buffer. 


System Flag 


Power-on reset occurred 
Self-test successful 


Command/Data 


A data byte written (port 60H) 
A command byte written (port 64H) 


Front Panel Keylock Status 


Keyboard inhibited 
Keyboard not inhibited 


Auxiliary (Mouse) Device Output Buffer Full 


Q= Output buffer is keyboard device data. 
1 = Output buffer is auxiliary device data. 
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6.2.2 


6.2.3 


Table 6-1. Status Register Bit Definition (continued) 


Data reception from the keyboard/auxiliary device terminated 
normally within the programmed time-out delay. 

Data from the keyboard/auxiliary device did not terminate 
normally within the programmed time-out delay. 


Parity Error 


Last byte of data received from the keyboard/auxiliary device 
had odd parity (no error). 

Last byte of data received from the keyboard/auxiliary device 
had even parity (error). 





Output Buffer 


The controller output buffer is an 8-bit read-only register at /O address 60H. The 
controller sends keyboard scan codes, command requested data bytes, and 
mouse data to the system via the output buffer. The significant data in the output 
buffer can be read only when the output buffer full bit (bit 0) of the status register 
equals 1. 


Input Buffer 


The controller input buffer is an 8-bit write-only register at I/O addresses 60H and 
64H. Data can be written to the input buffer only if the input buffer full bit (bit 1) of 
the status register equals 0. 


Writing to address 60H clears the command/data bit (bit 3) of the status register. 
Once cleared, the controller processes the data in the input buffer as a data byte. 
Data written to address 60H is sent to the keyboard, unless a system command 
instructs the controller to wait for a data byte. 
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Writing to address 64H sets the command/data bit (bit 3) of the status register to 
1. Once set, the controller processes the data in the input buffer as a command 
byte. 


6.2.4 Controller Commands 


The CPU uses controller commands (refer to Table 6-2) to control the operation 
of the controller and sense its status. The CPU writes controller commands into 
the input buffer through I/O port address 64H. 


Table 6-2. Controller Commands 


Read controller command byte 
Read 8742 internal RAM locations 21-3F 
Write controller command byte 
Write internal RAM locations 21-3F 
Disable auxiliary device (mouse) 
Enable auxiliary device 

Auxiliary interface test 

Self-test 

Keyboard test interface 

Disable keyboard 

Enable keyboard 

Read input port 

Poll input port low 

Poll input port high 

Read output port 

Write output port 

Write keyboard output buffer 
Write auxiliary output buffer 
Write to auxiliary device 

Read test input port 

Set/Clear output pin 

Output pulse 
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KEYBOARD/MOUSE INTERFACE 


The keyboard and mouse connect to the controller through bidirectional 
synchronous serial interface cables. Refer to Chapter 10 for the pin assignments 
of the Keyboard and mouse connectors. The controller supplies the keyboard 
and mouse with DC power of +5V +10% at a maximum current of 300 mA. 


The controller, keyboard, and mouse communicate using data and clock lines for 
synchronous serial communication. Open-collector drivers, at both ends of the 
cable, drive the data and clock lines. 


At power-up, the keyboard scans the signals on the clock and data lines and 
establishes a line protocol. A bidirectional serial interface in the keyboard 
converts the clock and data signals and transfers them to and from the keyboard 
through the keyboard cable. Signals include keyboard control commands from 
the system and keyboard scan and acknowledgment codes transferred to the 
controller. 


The serial data from the keyboard is called a scan code. Each keyboard key has 
an associated 11-bit scan code. Pressing and releasing a key generates a make 
or break scan code. The keyboard detects all keys pressed and transfers each 
scan code in the correct sequence to the controller. 


The controller receives serial data from the keyboard, checks the parity of the 
data, and translates the 8-bit scan code into system codes. It also interrupts the 
CPU to transfer data to the system. The controller interrupts the system when 
data is placed in its output buffer, or waits for the system to poll its status register 
to determine when data is available. 


The controller transfers various commands to the keyboard at any time. When 
the controller transfers data to the keyboard, it sets the data line to an inactive 
state and allows the clock line to go active. This action serves as a 
request-to-send (RTS) and a start bit. Setting the clock line to an inactive state 
inhibits keyboard transmission. 


If the controller has to transfer data to the keyboard during a keyboard transfer, 


the controller clamps the clock signal line to request a keyboard transfer halt. 
The clock line must remain low for at least 60 ms. 


Intel3886™ MicroComputer Model 300SX Board 


Keyboard and Mouse Controller 


6.3.1 


Intel386™ MicroComputer Model 300SX Board 


During the keyboard basic assurance test (BAT) or when no data transfer occurs, 
the clock line remains active (high). The keyboard holds the data line active 
(high). 


An inactive signal has a value between OV and +0.7V (logical 0). An active signal 
has a value between +2.4V and +5.5V (logical 1). These voltages are measured 
between a signal source and the DC network ground. 


Keyboard/Mouse Data Stream 


The 8-bit data stream, transferred serially over the data line, consists of one start 
bit, eight data bits, one odd parity bit, and one stop bit (refer to Table 6-3). A 
logic 1 indicates an active level and a logical 0 indicates an inactive level. The 
parity bit is either 1 or 0. The 8 data bits plus the parity bit always have an odd 
number of 1's. 


Table 6-3. Data Stream Bits 


Start bit (always 0) 
Data bit 0 (LSB) 
Data bit 1 

Data bit 2 

Data bit 3 

Data bit 4 

Data bit 5 

Data bit 6 

Data bit 7 (MSB) 
Parity bit (odd parity) 
Stop bit (always 1) 


1 
2 
3 
4 
5 
6 
7 
8 
9 
1 
1 
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Receiving Data from the Keyboard 


The keyboard transfers data to the controller in a serial format using an 11-bit 
frame. The first bit is a start bit, followed by 8 data bits, an odd parity bit, and a 
stop bit. A clock, supplied by the keyboard, synchronizes the data transfer. 


Before transferring data, the keyboard checks for a transmission-inhibit or 
controller RTS status on the clock and data lines. If transmission is inhibited 
(clock line inactive), keycodes are transferred to the keyboard buffer. During 
controller RTS, data is also stored in the keyboard buffer, while the Keyboard 
receives controller data. 


The keyboard transfers data to the controller only when both the clock and data 
signals are active. At the end of a transfer, the controller disables the interface 
until the system accepts the data byte. 


If a parity check error occurs, the controller signals the keyboard to transfer the 
data again. If the controller does receive the data correctly (after a set number of 
retries), an FFH code is sent to the controller output buffer. The parity bit in the 
status register is also set indicating a receive parity error. 


The controller times each data byte transfer from the keyboard. If a keyboard 
transfer does not end within 2 ms, the controller sets the receive time-out bit in 
the status register and writes an FFH code to its output buffer. No retries are 
attempted on a receive time-out error. 


The following commands are sent from the keyboard to the controller. 


OVERRUN OR KEY DETECTION ERROR (00H OR FFH) 


If the keyboard uses scan code set 1, the code equals FFH. For sets 2 and 3, 
the code equals OOH. The conditions are as follows: 


e The keyboard sends a key detection error character if conditions in the 
keyboard make it impossible to identify a switch closure. 


@ When the buffer in the Keyboard is full, an overrun character replaces the 


last transmitted code in the buffer. This code is sent to the controller when 
it reaches the top of the buffer queue. 
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KEYBOARD ID (83ABH) 


The keyboard ID consists of two bytes, 88ABH. The keyboard responds to the 
read ID with ACK, discontinues scanning, and sends the two.ID bytes. The 
keyboard sends the low byte first, followed by the high byte. The keyboard 
resumes scanning following an output of the keyboard ID. 


BAT COMPLETION CODE (AAH) 

Each time the system is powered up, the keyboard performs a self-test operation 
called the basic assurance test (BAT). The BAT consists of a keyboard 
processor test, a checksum of the ROM, and a RAM test. Activity on the clock 
and data lines is ignored during a BAT. The keyboard sends an AAH command 
to the controller following satisfactory completion of the BAT. Any other code 
indicates a keyboard failure. 

BAT FAILURE CODE (FCH) 

If a BAT failure occurs, the keyboard sends FCH, discontinues scanning, and 
waits for a controller response or reset. 

ECHO (EEH) 

When the controller issues the echo command to the keyboard, the keyboard 
sends EEH as a response to the controller. 

ACKNOWLEDGE (FAH) 

The keyboard issues an acknowledge to any valid input other than an echo or a 


resend command. If the keyboard is interrupted while sending an acknowledge, 
it discards acknowledge and responds to the new command. 
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RESEND (FEH) 


The keyboard sends the resend command when it receives an invalid input or 
any input with incorrect parity. This command signals the controller to transfer 
the input again. 


6.3.3 Sending Data to the Keyboard 


The controller transfers data to the keyboard in the same serial format used to 
receive data from the keyboard. Before the controller transfers data to the 
keyboard, it checks the keyboard and determines whether it is transferring data 
or not. If the Keyboard is transferring data, but has not reached the tenth clock 
signal, the controller overrides the keyboard output by setting the keyboard clock 
line inactive. If the keyboard transfer is beyond the tenth clock signal, the 
controller waits until the keyboard completes its transfer before transferring data. 


If the controller overrides the keyboard output, or if the keyboard is not 
transferring data, the controller sets the clock line inactive for more than 60 ps 
while preparing to transfer data. When the controller transfers the start bit, the 
clock line goes active. 


Each controller command or data transmission to the keyboard requires a 
response before the controller transfers its next output. After the keyboard 
receives a controller command, it returns an acknowledge code to the controller. 
If the Keyboard response is invalid or has a parity error, FEH is placed in the 
controller output buffer and the transmit time-out or parity error bits are set in the 
status register. 


The controller sets a programmed time limit (20 ms to 25 ms) for the keyboard to 
respond. If the keyboard cannot complete the send-out data process within this 
time period, the controller places FEH in its output buffer and sets the transmit 
and receive time-out error bits in its status register. No retries are attempted by 
the controller for any transmission error. The following commands are sent from 
the controller to the keyboard. 
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SET/RESET STATUS INDICATORS (EDH) 


The set/reset status indicators command activates or deactivates the three LED 
indicators (Num Lock, Caps Lock, and Scroll Lock) on the keyboard. 


The keyboard responds to the command byte with ACK, discontinues scanning, 
and waits for the option byte from the controller. The contents of the option byte 
following the command determines the parameter for setting the LED mode. Bits 
0, 1, and 2 of this byte control the Scroll Lock, Num Lock, and Caps Lock LEDs 
respectively. Bits 3 through 7 are reserved. 


If the bit for an indicator equals 1, the indicator turns on. If the bit equals 0, the 
indicator turns off. The keyboard responds to the option byte with an 
acknowledge code, sets the indicators, and resumes scanning. 


ECHO (EEH) 


The echo command tests the keyboard command process. When the keyboard 
receives this command, it issues an EEH response, and continues scanning. 


INVALID COMMAND (EFH AND F1H) 


EFH and F1H are invalid commands. 


SELECT ALTERNATE SCAN CODES (F0H) 


The select alternate scan codes command instructs the keyboard to select one of 
three sets of scan codes. The keyboard acknowledges receipt of this command 
with an acknowledge code, then clears both the output buffer and the typematic 
key (if active). When the controller sends the option byte, the keyboard responds 
with another acknowledge code. An option byte value of 01H selects scan code 
set 1, 02H selects set 2, and O3H selects set 3. Byte value OOH causes the 
keyboard to respond with an acknowledge code and send a byte signaling the 
controller which scan code set is in use. 
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READ ID (F2H) 


The read ID command requests identification information from the keyboard. The 
keyboard responds with an acknowledge code, discontinues scanning, and 
sends the two keyboard ID bytes. The second byte must follow completion of the 
first byte within 500 ps. After the output of the second ID byte, the keyboard 
resumes scanning. 


SET TYPEMATIC RATE/DELAY (F3H) 


This command sets the typematic rate and delay. The keyboard responds with 
an acknowledge code, stops scanning, and waits for the controller to issue the 
rate/delay value byte. Once issued, the keyboard responds with another 
acknowledge code, sets the rate and delay to the values indicated, and resumes 
scanning. 


The contents of the rate/delay value byte following the command determines the 
parameters for these two functions. Bits 4:0 set the typematic rate, bits 5 and 6 
set the delay parameter, and bit 7 is set to zero. 
The following equations show the calculation for the delay and the typematic rate: 
e@e Delay = (1 + C) x 250 ms + 20% 
@ Period T = (8 + A) x 28 x 0.00417 seconds 
e@ Typematic Rate = 1/T + 20% (default is 10 characters per second) 
Where: C = Binary value of bits 5 and 6 (default equals 500 ms) 
A = Binary value of bits 2, 1, and 0 
B = Binary value of bits 4 and 3 
T = Interval from one typematic output to the next 
ENABLE (F4H) 
When the keyboard receives the enable command, it responds with an 


acknowledge code, clears its output buffer, clears the last typematic key, and 
starts scanning. 
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DEFAULT DISABLE (F5H) 


The default disable command resets all conditions to the power-on default state. 
The keyboard responds with an acknowledge code, clears its output buffer, sets 
the default key types and typematic rate/delay, and clears the last typematic key. 
The keyboard stops scanning and waits for further instructions from the 
controller. 


SET DEFAULT (F6H) 


The set default command is similar to default disable command F5H. However, 
the keyboard continues scanning instead of stopping and waiting for further 
instructions. 


SET ALL KEYS (F7H, F8H, F9H, FAH) 


The set all keys commands, F7H, F8H, F9H, and FAH, instruct the keyboard to 
set all keys to typematic, make/break, make, and typematic/make/break 
respectively. The keyboard responds with an acknowledge code, clears its 
output buffer, sets all keys to the type indicated by the command, and continues 
scanning. Although these commands are sent using any scan code set, they 
affect only scan code set 3. 


SET KEY TYPE (FBH, FCH, FDH) 


The set key type commands, FBH, FCH, and FDH, instruct the keyboard to set 
individual keys to typematic, make/break, and make respectively. The keyboard 
responds with an acknowledge, clears its output buffer, and prepares to receive 
key identification. The controller identifies each key by its scan code value as 
defined in scan code set 3. Only scan code set 3 values are valid for key 
identification. The type of each identified key is set to the value indicated by the 
command. 
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RESEND (FEH) 


The controller transfers the resend command when it detects an error in any 
transfer from the keyboard. It requests the keyboard to resend a code that was 
detected as an error. This command transfers only after a keyboard transfer and 
before the controller allows the next keyboard output. When a resend command 
is received, the keyboard transfers the previous output again. If the previous 
output was resend, the Keyboard transfers the last byte before the resend 
command. 


RESET (FFH) 


The controller issues the reset command to start a program reset and a keyboard 
internal self test. The keyboard responds with an acknowledge code and 
ensures the controller accepts the acknowledge code before executing the 
command. The controller raises the clock and data lines for a minimum of 500 us 
after receiving an acknowledge code from the keyboard. The keyboard remains 
disabled from the time it receives the reset command until the controller 
responds to the acknowledge code, or until another command overrides the 
previous command. After the controller responds to the acknowledge code, the 
keyboard initializes and performs the BAT. After returning the completion code, 
the keyboard defaults to scan code set 2. 


System-to-Mouse Commands 


The write to auxiliary device command (D4) instructs the 8742 to transmit the 
next byte it receives to the auxiliary device. All commands written to the mouse 
must be written must be preceded by the write to auxiliary device command to 
port 64H, followed by the desired mouse command. All mouse commands must 
be written to port 60H. If the write to auxiliary device command to port 64H is not 
executed first, all mouse commands will be directed to the keyboard. 
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RESET SCALING (E6H) 


The reset scaling command resets the scaling to 1:1. 


SET SCALING (E7H) 


The set scaling command sets the scaling to 2:1. This command can only be 
used when the mouse is in stream mode. When in stream mode, the current X/Y 
coordinates values are converted to new values each time the sample period 
expires. In 2:1 scaling, the new relationship between the input and output values 


is as follows: 
Input Output 
) 6) 
1 1 
2 1 
3 3 
4 6 
5 9 
N(>=6) 2.0xXN 
SET RESOLUTION (E8H) 


The set resolution command is a two byte command. The second byte (also 
written to port 60H) is interpreted as a resolution in counts per mm. There are 
four possible resolutions. The relationship between the second byte and the 
resolution is as follows: 


Byte Resolution 

OOH 1 count per mm 
01H 2 counts per mm 
02H 4 counts per mm 
03H 8 counts per mm 
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STATUS REQUEST (E9H) 


The status request command generates a three byte status report. The format of 
the mouse status request bytes is shown in Table 6-4. 


Table 6-4. Format of Status Request Bytes 


Sampling Rate 


Bit 7 = 
Bit 0 = 


Resolution 


Bit 7 = 
BitO = 


Mouse status 


Bit 7 = 
Bit 6 = 


Bit 5 = 
Bit 4 = 
Bit 3 = 
Bit 2 = 


Bit 1 = 
Bit 0 = 


6-16 


0 
{ 
0 
1 
0 
1 


Most significant bit 
Least significant bit 


Most significant bit 
Least significant bit 


Reserved 

Stream mode 

Remote mode 

Disabled 

Enabled 

Scaling 1:1 

Scaling 2:1 

Reserved 

Left mouse button pressed 
Reserved 

Right mouse button pressed 
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SET STREAM MODE (EAH) 

In set stream mode, the mouse transmits data to the system each time a mouse 
button is pressed or released, or each time the mouse detects a unit of 
movement. The mouse data sample rate determines the maximum number of 
times per second that mouse data can be transmitted to the system. If no button 
is pressed or if the mouse is not moved, no data is transmitted. The set stream 
mode command enables the stream mode. 

READ DATA (EBH) 

The read data command forces the transmission of one mouse data packet. The 
read data command is valid in both stream mode and remote mode. 


RESET WRAP MODE (ECH) 


The reset wrap mode command resets the mouse to normal operation. 


SET WRAP MODE (EEH) 
This command sets wrap mode; the mouse "echo" mode. With the exception of 


the reset wrap mode (ECH) and reset mouse (FFH) commands, the mouse will 
echo all data and commands received from the system. 


SET REMOTE MODE (FOH) 


This command sets remote mode; the mouse data can only be transmitted in 
reply to a read date command. 


READ DEVICE TYPE (F2H) 


The read device type command reads the mouse ID byte. The mouse returns a 
value of OOH to the read device command. 
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SET SAMPLING RATE (F3H) 


This command sets the sampling rate of the mouse. The sampling rate is 
defined as the number of times per second that the system checks for mouse 
data. This is a two byte command. The set sampling rate command (F3H) must 
be followed by a second byte that represents the hex value of the sampling rate. 
The allowable values are defined below: 


Hex Value Sampling Rate 

OAH 10 samples/second 
14H 20 samples/second 
28H 40 samples/second 
3CH 60 samples/second 
50H 80 samples/second 
64H 100 samples/second 
C8 200 samples/second 

ENABLE (F4H) 


The enable command enables data transmissions if the mouse has been set to 
stream mode. This command has no effect in remote mode. 


DISABLE (F5H) 


The disable command disables data transmissions if the mouse has been set to 
stream mode. This command has no effect in remote mode. 
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SET DEFAULT (F6H) 


The set default command reinitializes the mouse to its power-on default state. 
The mouse power-on default state is shown below: 


Sampling rate 100 samples/second 


Scaling Linear scaling 
Mode Stream mode 
Resolution 4 counts/mm 


Transmissions Disabled 


RESEND (FEH) 

The resend command is issued by the system in response to transmission errors 
from the mouse. The mouse responds to this command by retransmitting its last 
data packet. 


RESET (FFH) 


The reset command instructs the mouse to run its internal self-test routine. This 
command puts the mouse into reset mode. 
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6.3.5 Mouse-to-System Replies 


There are two mouse-to-system replies. Both replies are related to command 
processing and are read by the system at port 60H. 


ACKNOWLEDGE (FAH) 


The mouse replies with an acknowledge (FAH) whenever it receives a valid 
command from the system. Unlike mouse serial data packets, the acknowledge 
reply is not stored in a buffer in internal memory, but is discarded immediately 
after it is transmitted. If a new command is received while the mouse is in the 
acknowledge reply process, the mouse discards the acknowledge reply and 
begins processing the new command immediately. 


==> NOTE 
The reset wrap mode (ECH) and reset (FFH) commands are exceptions to 
mouse acknowledge response. The mouse does not respond with an 
acknowledge to either of these commands. 


RESEND (FEH) 


The mouse replies with a resend (FEH) whenever it receives an invalid command 
from the system. Two invalid commands in succession cause the mouse to send 
the error code FCH to the system. A single isolated invalid command does not 
affect mouse processing in any way. The mouse ignores single invalid 
commands and maintains its present operational state. 
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7.2 


INTRODUCTION 


This chapter describes the onboard video display subsystem (VDS). The chapter 
contains an overview of the video display controller, the graphics chip set, and 
the digital-to-analog converter (DAC). 


VIDEO DISPLAY SUBSYSTEM OVERVIEW 


The VDS consists of a graphics chip set, a digital to analog convertor (DAC), 
256K of dynamic random access memory (DRAM), and support logic (see Figure 
7-1). The chip set supports high resolution graphics and alphanumeric display 
modes for both monochrome and color, and for high resolution variable 
frequency monitors. Video outputs are either TTL or analog voltage levels. An 
external palette, provided by the DAC, supports up to 256 colors from a possible 
262,144 colors. A 32-bit data bus supports video memory configurations up to 
256K (four 64K planes). The graphics chip set contains a hardware 
implementation of video graphics array (VGA), enhanced graphics adapter 
(EGA), color graphics adapter (CGA) monochrome display adapter (MDA), and 
Hercules graphics adapter (HGC). 


==> NOTE 
The VDS does not support a video feature connector. 


The VDS is controlled by the onboard video BIOS. The video BIOS is located at 
memory address EQQOOH-E7FFFH and resides in two 27512 EPROM devices. 
The video BIOS can be optionally mirrored to COOOOH-C7FFFH during system 
setup. 
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Figure 7-1. Video Display Subsystem Block Diagram 
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GRAPHICS CHIP SET 
The Cirrus Logic GD510A Graphics Attributes and GD520A Sequencer/CRT 
Controller devices comprise the graphics chip set on the 300SX board. The four 
major operations supported by the graphics chip set are as follows: 

e CPU access to the registers within the graphics chip set 

e@ CPU access to video memory 


e Video memory refresh 


e Display access to video memory 


CPU Access to Registers 


The CPU accesses the graphics chip set registers by setting up 20-bit addresses 
and generating IOR* and lOW* signals to read or write 8-bit data. 


CPU Access to Video Memory 


CPU access to video memory is channeled through the graphics chip set. The 
CPU must set up the proper address, data, and timing parameters in the 
graphics chip set registers in order to connect one of the four video memory byte 
plane buses to the CPU data bus. 


The graphics chip set also contains an intelligent address sequencer that 
allocates video memory cycles not only to the CPU, but also to the DRAM refresh 
controller and the display CRT controller. 


Video Memory Refresh 


Memory bandwidth is allocated to each process according to the actual real time 
needs of the process. This ensures efficient use of the available bandwidth. 
During horizontal and vertical retrace intervals the display is blanked, which frees 
up memory bandwidth for host access and/or memory refresh. 
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7.3.4 


7.4 


7.4.1 


Display Access to Video Memory 


The GD520A sequencer/CRT controller device works closely with the GD510A 
graphics/attributes device in all video modes. The GD510A contains the video 
memory data interface as well as the video outputs to the monitor. Display data 
is latched in the GD510A after the GD520A determines where the data is located. 
The GD510A contains video shift registers to interface to a monitor.. 


DIGITAL-TO-ANALOG CONVERTOR (DAC) 


The digital-to-analog convertor device (DAC0631) contains a 256 x 18-bit color 
palette. The color palette provides a display of 256 colors selected from a total of 
262,144. Three internal 6-bit video DACs convert the 18-bit digital signal to a red, 
green, and blue (RGB) analog output (OV to 0.7V). 


DAC to CPU Interface 
The DAC to CPU interface consists of three internal registers: pixel address, color 
value, and pixel mask. The contents of the color palette are accessed through 


the color value and pixel address registers. Register select signals, RSO and 
RS1, determine which register is accessed by the CPU (refer to Table 7-1). 


Table 7-1. Register Select Signals Bit Assignments 


Pixel Address (write only) 


Pixel Address (read only) 
Color Value 
Pixel Mask 
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PIXEL ADDRESS REGISTER (PAR) 


The PAR is a byte-wide latch that receives and latches address information 
applied to D7:0. The register select signals (RSO and RS1) determine if the PAR 
is used in the read or write mode. The PAR latches color palette addresses prior 
to the CPU writing new color definitions to the color palette. The PAR also 
latches color palette addresses prior to the CPU reading the color definitions in 
the color palette. 


COLOR VALUE REGISTER (CVR) 


The 18-bit wide CVR buffers the interface between the CPU and the color palette. 
A color definition can be read from or written to the CVR by a sequence of three 
byte-wide transfers. Only the least significant six bits (D5:0) of a byte contain 
color information when reading from or writing to the CVR; the most significant 
bits are set to 0. The first byte placed on the data I/O lines during a CVR read 
contains the red value. The next byte contains the green value and the last byte 
contains the blue value. After a completed read or write sequence to the CVR, 
the PAR is automatically incremented. 


PIXEL MASK REGISTER (PMR) 


The byte-wide PMR masks selected bits of the pixel address values applied to 
the pixel address inputs (P7:0). A 1 in any location in the PMR leaves the 
corresponding bit in the pixel address unchanged. A 0 resets the corresponding 
bit to 0. The operation of the PMR does not affect the address of the color 
definition during a CPU color palette access. 
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VIDEO MODES 


The VDS includes all registers and data paths required for VGA/EGA, CGA, MDA, 
and HGC controllers. In addition, several clocks are provided on the board to 
support the various video modes and monitors. The graphics chip set selects 
the appropriate clock for the current mode and monitor type. 


Extended graphics resolutions beyond the 720 x 400 VGA standard are possible 
using a multiple frequency monitor such as the NEC Multisync. Extended modes 
include: 


@ 720 x 540 graphics resolution with 4:3 aspect ratio 
e 800 x 600 graphics resolution with 4:3 aspect ratio 


e High resolution text modes 


The VDS also supports an extended mode 13 where four pages of 64K blocks of 
memory can be switched and displayed instead of the standard single page. 
This allows for animation using 256 displayable colors without requiring a large 
amount of data to be manipulated (64K maximum size per image). Table 7-2 
lists the standard video modes and Table 7-3 lists the extended video modes 
available on the VDS. 
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Table 7-2. VDS Standard Video Modes 


Character 
Type Colors} Columns} Rows | Size 
4 40 25 


Text 
Text 
Text 
Text 
Text 
Text 
Text 
Text 
Text 
Text 
Text 
Text 
Graphics 
Graphics 
Graphics 
Text 
Text 
Graphics 
Graphics 
Graphics 
Graphics 
Graphics 
Graphics 
Graphics 
Graphics 


+ EGA style text modes with 8 x 14 and 9 x 14 character sizes and 350 lines 
vertical resolution. 

t VGA style text modes with 9 x 16 character size and 400 lines vertical 
resolution. 
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Resolution 


320 x 200 
320 x 350 
360 x 400 
320 x 200 
320 x 350 
360 x 400 
640 x 200 
640 x 350 
720 x 400 
640 x 200 
640 x 350 
720 x 400 
320 x 200 
320 x 200 
640 x 200 
720 x 350 
720 x 400 
320 x 200 
640 x 200 
640 x 350 
640 x 350 
640 x 480 
640 x 480 
320 x 200 
720 x 348 
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Table 7-3. VDS Extended Video Modes 


Mode Character 
(Hex) | Type Colors | Columns| Rows | Size Resolution 


Text 
Text 
Text 


Text 


Text 
Text 
Text 
Text 
Graphics 
Graphics 





VIDEO INTERFACE 


900 x 390 
800 x 400 
800 x 480 
800 x 600 
1056 x 390 
1056 x 400 
1056 x 480 
640 x 480 
720 x 540 
800 x 600 


The 300SX board has two video interface connectors, J5 and J6. J5 is a 15-pin 
female connector intended for use with an analog monitor. J6 is a 9-pin female 
connector intended for use with a digital (TTL) monitor. The pinouts of the two 
video interface connectors are listed in Chapter 10 
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INTRODUCTION 


This chapter describes the operation of the onboard Intel 82072 floppy disk drive 
controller. The architecture of the 82072 is discussed with regard to its software 
interface, followed by a description of its control and data transfer commands, 
and a definition of its input and output signals. The chapter concludes with a 
description of two external registers used in conjunction with the controller. 


82072 ARCHITECTURE 
An Intel 82072 floppy disk drive controller provides the data interface between the 
floppy disk drive and the central processing unit (CPU). The system interface 
consists of a parallel interface unit (PIU) and several registers (see Figure 8-1). 
The PIU has an 8-bit bi-directional data bus which handles all of the data 
transfers to and from the system bus. 
The 82072 contains the following registers: 

e@ Main status (MSR) 

e Datarate select (DSR) 


e First in first out (FIFO) 
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Figure 8-1. 82072 Block Diagram 
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The MSR, DSR, and FIFO are selected with different combinations of the RD*, 
WR%, and AO pins (refer to Table 8-1). 


Table 8-1. Controller Register Set Selection 









pao | eo 
0 0 0 Illegal 
0 0 1 Read the MSR 
) 1 0 Write to the DSR 
0 1 1 Data bus is tri-stated 
1 0 0 Illegal 
1 0 1 Read the FIFO 
1 1 0 Write to the FIFO 
1 1 1 


Data bus is tri-stated 


Main Status Register 


The MSR is an 8-bit read-only register and may be accessed at any time (before, 
during, and after a command). The CPU reads the MSR to determine if the 
controller is ready. If the controller is ready, the CPU sends a command, 
followed by the correct parameters, to the controller through the FIFO (data port). 
The FIFO should be accessed only when the request for master (RQM) bit in the 
MSR is set, or when the DRQ input is active during a DMA transfer. 


REQUEST FOR MASTER (RQM) BIT 

When set to 1, the RQM bit (bit 7) indicates the CPU can access the FIFO. Ifthe 
RQM bit is set to 0, accesses to the FIFO should not be attempted. 

DATA IN/OUT (DIO) BIT 

The DIO bit indicates the direction of data transfer from the FIFO (the RQM bit 


must be set). When the DIO bit is set to 1, the CPU removes data bytes from the 
FIFO. When the DIO bit is set to 0, the CPU writes data bytes into the FIFO. 
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NON-DMA MODE (NDM) BIT 


Selecting the non-DMA mode in the specify command, sets the NDM bit (bit 5) to 
1, during the execution phase of acommand. The NDM bit supports polled data 
transfers along with the RQM and DIO bits. The NDM bit remains a zero if DMA 
mode is selected. The NDM bit differentiates between the execution and result 
phases of a non-DMA Data command. 


CONTROLLER BUSY (CB) BIT 


When set to 1, the CB bit (bit 4) indicates the controller is processing a 
command. The CB bit is set during the command phase after the command byte 
has been accepted. When set to 0 at the end of the result phase, the CB bit 
indicates the start of the next command phase. If the command has no result 
phase (i.e., seek and recalibrate), the CB bit is set to 0 after receiving the last 
byte in the command phase. 


DRIVE BUSY (DB) BITS 


The DB bits (bit 3:0) are set only when a drive is in the seek portion of a 
command, including implied seeks, overlapped seeks, and recalibrates. 


Data Rate Select Register (DSR) 


The DSR (write-only) specifies the data transfer rate between the controller and 
the floppy disk drive. The data transfer rate can be selected for the internal and 
external data separator, the data transfer rate, and the write pre-compensation 
delays. Setting the appropriate bit in the DSR invokes the power-down mode 
and a software reset. 


The CPU loads data into the DSR after an internal synchronization delay. The 
CPU should not try to perform successive writes to the DSR until the 
synchronization time has elapsed (24 clock periods at 24 MHz or 1 ps). The DSR 
should be programmed before issuing a command that accesses the disk and 
uses values that the DSR controls. There is no minimum delay between writing 
the DSR and accessing the FIFO and MSR. 
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The contents of the DSR, and the logic it controls, are altered if a write to the DSR 
occurs during data transfers. Data rate and pre-compensation values change 
and may give undesirable results. 


Upon a hardware reset, the DDRE pin setting determines the configuration of the 
DSR . Tieing DDRE high configures the DSR upon power up and reset. When 
DDRE is tied low, the DSR retains the current data rate and pre-compensation 
values. 


In the case of the software reset, if EPLL equals zero and DDRE equals one, the 
data rate select and pre-compensation field resets to 00010. Under these 
conditions, a second write to the DSR without a software reset is needed if a 
different data rate or pre-compensation value is required. 


SOFTWARE RESET (SWR) BIT 


Setting the SWR bit (bit 7) to 1, enables software reset of the controller. During a 
software reset, the controller internally holds the reset active for 12 to 15 clock 
cycles, depending on the state of the internal state machine. The CPU must wait 
for the request for master bit (bit 7 of the MSR) to be set before issuing any 
commands. During the initialization period following a software reset, the 
controller does not accept commands from the CPU. 


A command may be aborted by setting the software reset bit. However, after a 
software reset, the specify command has to be re-issued because a software 
reset clears the parameters set by this command. The specify command 
initializes the step rate time, the head load time, and the head unload time. 


POWER DOWN (PD) BIT 


Setting the PD bit (bit 6) to 1, initiates the controller into its power down mode. 
The controller performs a software sequence before entering the power down 
state. During power down, the controller shuts off the clock oscillator. Only write 
operations to the data rate select register are allowed during power down. 
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ENABLE PLL (EPLL*) BIT 


Setting the EPLL* bit (bit 5) to 0, enables the internal PLL data separator, and the 
DW/DDRE pin operates in DDRE mode. When the EPLL* bit is set to 1, the 
external data window signal is ignored. The EPPL* bit internally generates the 
data window signal used to extract data bits from the serial clock and data bit 
stream. 


PRE-COMPENSATION (PRECOMP) BITS 


The controller has write pre-compensation circuitry that internally adjusts the write 
data pulses before sending it to the disk drive. A programmed compensation 
interval (refer to Table 8-2) is added to or subtracted from the normal write pulse 
timing as a function of the data pattern. The configure command specifies the 
track number that pre-compensation starts upon. If a configure command is not 
issued, the controller defaults to beginning pre-compensation on track 0. 


The controller defaults to PC-AT compatible pre-compensation values when the 
DSR register is programmed with PRECOMP bits (bits 2 - 4) set to zeroes. The 
pre-compensation value chosen (refer to Table 8-3) depends upon the 


_ programmed data transfer rate (DRATESEL bits 0 and 1). 
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Table 8-2. Programmed Pre-Compensation Delays 


PRECOMP Bits Pre-Compensation Delay 
432 


OoOf-433000- 
O-00A=02 


0.00 ns (Disabled) 
41.67 ns 


83.34 ns 
125.00 ns 
166.67 ns 
208.33 ns 
250.00 ns 
Default 


Table 8-3. Default Pre-Compensation Delays 


1Mb/s 


500Kb/s 
300Kb/s 
250Kb/s 
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DATA RATE SELECT (DRATESEL) BITS 


The DRATESEL bits (bits 0 and 1) program both the read and write data rates 
(refer to Table 8-4). 


_ Table 8-4. Controller Supported Data Transfer Rate 


DRATESEL Data Rate 
Bit1 Bit 0 MFM 


1Mb/s -- 

500Kb/s 250Kb/s 
300Kb/s 150Kb/s 
250Kb/s 125Kb/s 





FIFO 


The controller has a 16-byte FIFO with a programmable threshold set by the 
configure command. Threshold is the number of bytes available to the controller 
when service is requested from the CPU, and ranges from 1 to 16. 


The parameters determining the optimal threshold value are the parallel bus 
frequency (Fp), serial data transfer rate (Fs), and the bus latency time (in the 
range between NAmax and NAmin). The ratio of Fp/Fs determines the 
relationship between how fast the FIFO fills and how fast it empties. The bus 
latency time determines how long the controller has to wait before being 
serviced. If Fs is the serial data rate, then Fs/8 is the serial data rate in bytes per 
second. The data rate of the system depends on the system clock frequency 
and the number of clock cycles required to transfer one byte of data (n). 


In order for the parallel side to keep up with the serial side, the following must 


hold true: (Fp/n)/(Fs/8) > 1. This equation assumes the parallel interface section 
reads and writes data at a faster rate than the serial section. 
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It takes a number of clock cycles to acquire the system bus. NAmin is the 
minimum time required to acquire the system bus and NAmax is the maximum. 
To prevent underrun or overrun, the maximum bus acquisition time must be less 
than the time to fill the FIFO from the threshold limit. For a write operation, the 
maximum bus acquisition should be less than the time to empty the FIFO from 
the threshold limit. 


8.2.4 Control Commands 

The control commands position the head on the desired track and obtain 
information regarding the status of the floppy disk drives. The control commands 
are as follows: 

e Read id 

e@ Seek 

e Recalibrate 

e Sense interrupt status 

e Sense drive status 

@ Specify 

e Configure 

e@ Relative seek 

e Motor on/off 

e Dumpreg 


The read id command is used to find the present position of the recording heads. 
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The seek and recalibrate commands, executed prior to a data transfer command, 
position the read/write head over the desired cylinder. CPU involvement does 
not occur during the execution phase of the seek and recalibrate commands. At 
the end of the execution phase, the controller generates an interrupt. A sense 
interrupt status command must be issued in response to the interrupt. 


The sense drive status command performs between other commands to 
immediately obtain the status of any one of the floppy disk drives. The sense 
drive status command has no execution phase and generates no interrupts. 


The specify command sets the initial values for each of the three internal timers: 
Head Unload Time (HUT), Step Rate Time (SRT), and Head Load Time (HLT). 


The configure command is issued to select special features of the 82072. A 
configure command need not be issued if the default values of the 82072 meet 
the system requirements. 


The relative seek command differs from the seek command in that it steps the 
head by the absolute number of tracks specified in the command instead of 
making a comparison against an internal register. 


The motor on/off (mon/moff) command provides software control of the motor 
pin. This command has no execution phase and generates no interrupts. 


The dumpreg command supports system run-time diagnostics and application 
software development and debug. The dumpreg command can be issued 
following the specify or the configure command, to determine if proper 
communication between the CPU and the controller exists. The dumpreg 
command has no execution phase and generates no interrupts. 
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8.2.5 Data Transfer Commands 


The controller supports six data transfer commands. They are as follows: 


Read data 


Read deleted data 


Read a track 


Write data 


Write deleted data 


Format track 


The data transfer commands all require the same parameter bytes and return the 
same status bytes. The only difference between the individual data transfer 
commands are the coding of bits 4 - 0 (D3:0) in the first command byte sent to 
the controller (refer to Table 8-5). 


Table 8-5. Data Transfer Coding 


Read data 


Read deleted data 
Write data 
Write deleted data 
Read track 





Intel386™ MicroComputer Model 300SX Board 8-11 


Floppy Disk Drive Controller 





8.2.6 Signal Definitions 


TC (1) 


TC (terminal count) terminates requests for data transfers. Disk read and write 
commands complete the transfer to the current sector with valid CRC 
checking/generation. 


IDX (1) 


IDX (index) indicates the beginning of a track. It counts retries and delay periods 
for internal (i.e., motor on/off) timers and is rising-edge triggered. 


INT (O) 


INT (interrupt) indicates command completion or a required data transfer 
(depending upon the data transfer mode). Command completion interrupts are 
cleared by reading the STO status register. Data transfer interrupts are cleared 
when the amount of data in the FIFO reaches the full or empty level (depending 
on FIFO direction) or a TC is issued. 
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RESET (I) 


RESET places the controller in a known idle state. All disk outputs are set to a 
low level. All registers, except those set by the specify command, are cleared. 


From the trailing edge of reset, there is a maximum delay of 8 us until the main 
status register is valid. Following reset, the controller defaults to polling enabled. 
The default values are as follows: 


e Internal data separator is enabled. 

@ Write pre-compensation value is 125 ns. 
e@ Motor on delay is 0.0 seconds. 

e@ Motor off delay is 5.2 s. 

e Data rate is dependent on DDRE setting. 


@ FIFO is disabled. 


DW/DDRE (1) 


DW/DDRE (data window/default data rate enabled) samples the read data input. 
When the internal PLL is used, this input pin defines the data rate and write pre- 
compensation values after reset. DDRE tied high causes the data rate and pre- 
compensation bits of the DSR to reinitialize to the default values of 250Kb/s and 
125 ns delay when a hardware/software reset is issued. DDRE tied low causes 
the current data rate and pre-compensation values in the DSR to be retained 
when a hardware reset is issued. During a software reset, the DSR contains 
those values written into the register. DDRE tied low should be used in 
applications where data rate and pre-compensation information needs to be 
retained regardless of device reset. 
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RDDATA (1) 


RDDATA (read data) is serial FM or MFM encoded data from the disk drive. 


VCO (O) 

VCO (read data gate) enables an external PLL to synchronize to read data input 
from the disk drive. 

LD (O) 

LD (low density) modifies read/write head and data channel characteristics. This 
signal activates when internal PLL is enabled and a data transfer rate of 250 or 
300Kb/s is chosen. 

WE (O) 


WE (write enable) enables the head to write onto the disk. 


MFM (O) 

MFM (MFM mode) selects between single (FM) and double density (MFM) 
modes. A1 = MFM and an0O = FM mode. 

MOTOR (O) 

MOTOR (motor enable) activates the drive motor on the selected drive. Delays 


are programmable. With one output, this pin must be qualified with the drive 
select logic to provide motor enables for each drive. 
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HDSEL (0) 


HDSEL (head select) selects one of two sides on the disk. AO = side 0 anda 
1 = side 1. 


DS1:0 (O) 


DS1:0 (drive select) selects one of four disk drives. DSO, DS1 = 0,0 selects drive 
0. 


WRDATA (0) 


WRDATA (write data) writes FM or MFM encoded serial data to the disk drive. 
No external pre-compensation is required. 


TRKO (1) 


TRKO (track 0) indicates the head is on physical track 0 (outermost track). 


WP (I) 


WP (write protect) indicates if the disk is physically write protected. 


RDY (1) 


RDY (ready input) indicates whether the drive is ready for an operation. 


HDL (0) 


HDL (head load) loads the head onto the disk drive if required. 
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8-16 


STP (O) 


STP (step) supplies step pulses to the disk drive. 


DIR (O) 


DIR (direction), in conjunction with the STP input, causes the drive to move the 
head out if 0, and in if 1. 


EXTERNAL REGISTERS 
To support different capacity drives, the controller circuitry of the 300SX board 
incorporates two registers that are external to the 82072. The two registers are 
as follows: 

@ Digital Output Register (DOR) 

@ Digital Input Register (DIR) 


These two registers are described in the following sections. 


Digital Output Register (DOR) 

The Digital Output register is a write-only register located at I/O address 3F2H. 
Bits 1, 5, 6, and 7 of the register are reserved and can be set to either a 1 or a0. 
The remaining bits are described below. 


DRIVE SELECT 


When set to 0, the Drive Select bit (bit 0) indicates that drive A is selected. If the 
Drive Select bit is set to 1, it indicates that drive B is selected. 
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DISKETTE FUNCTION RESET 


When the Diskette Function Reset bit (bit 2) is set to 0, the diskette reset function 
is disabled. 


ENABLE DISKETTE DMA AND INTERRUPTS 


When the Enable Diskette DMA and Interrupts bit (bit 3) is set to 1, the DMA and 
interrupt lines are enabled. 


DRIVE A MOTOR ENABLE 


When the Drive A Motor Enable bit (bit 4) is set to 1, the Motor A enable signal is 
activated. A timer is dedicated to perform the motor disable function. The timer 
is initialized by the BIOS, based on the command selected. 


DRIVE B MOTOR ENABLE 


When the Drive B Motor Enable bit (bit 5) is set to 1, the Motor A enable signal is 
activated. A timer is dedicated to perform the motor disable function. The timer 
is initialized by the BIOS, based on the command selected. 


Digital Input Register (DIR) 


The Digital Input register is a read-only register located at I/O address 3F7H. Bit 
7 is the only bit used by the floppy disk drive controller. Bit 7 can only be driven 
when a high capacity disk drive is active. If bit 7 is set to a 1, it indicates to the 
system that the floppy disk in the disk drive has been changed. This bit is 
automatically reset by the disk drive when a seek operation is performed. 
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9.2.1 


INTRODUCTION 


This chapter provides an overview of the ISA bus interface as implemented on 
the 300SX board. 


BUS AGENTS 


The ISA Bus allows several different bus agents. A bus agent is a physical unit 
which has an interface directly to the ISA Bus. A memory expansion board, a LAN 
controller, and a modem are all examples of bus agents. The two basic types of 
bus agents are Requesting Agents and Replying Agents. 


Requesting Agents 


Requesting Agents initiate an ISA Bus cycle. Requesting Agents can be either a 
Primary Requesting Agent (PRA) or a Secondary Requesting Agent (SRA). 


The PRA has immediate access to the ISA Bus when control has not been 
granted to a Secondary Requesting Agent. The only PRA allowed is the 300SX 
board. 


The SRA is an optional Requesting Agent that normally does not have immediate 
control of the ISA Bus. Control of the bus is requested from the Primary 
Requesting Agent. Multiple Secondary Requesting Agents are allowed. An SRA 
must have a 16-bit bus interface. No 8-bit SRA’s are allowed on the ISA Bus. 
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9.2.2 Replying Agents 


A Replying Agent (RPA) responds to ISA Bus cycles initiated by a Requesting 
Agent. An RPA cannot initiate ISA Bus cycles. 


9.2.3 Configuration of Bus Agents 


The ISA Bus services 5 agents via 8-bit and 16-bit portions of the bus. The 
number of each agent type that is supported is as follows: 


Requesting Agent 1-5 (PRA + 4) 
Primary Requesting Agent 1 (PRA) 
Secondary Requesting Agent 0-4 


Replying Agent 0-4 


9.2.4 Agent Functional Model 


Table 9-1 describes the types of ISA Bus cycles in which ISA bus agents may 
participate. 
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Table 9-1. ISA Bus Cycles 


Primary Initiates: 
Requesting Agent 


Responds to: 


Secondary Initiates: 
Requesting Agent 


Responds to: 


Gains Bus 


Ownership by: 


Replying Agent Responds to: 


Memory access 
I/O access 
DMA access 
Global refresh 


Interrupt request 
DMA request 
Bus arbitration request 


Memory access 
\/O access 


Global refresh 


DMA request 

Assuming bus ownership on 
DMA grant 

Assuming responsibility for 
refresh initiation 


Memory access 
/O access 
DMA access 
Global refresh 


Seeks PRA service 


through: 
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GENERAL ISA BUS ATTRIBUTES 


The ISA Bus has the following general attributes: 


The memory address space is 24 bits long and the data path is 16 bits 
wide, providing a 16M memory address space with 8 and 16-bit data 
transfers. 


The I/O address space is 16 bits long and the data path is 16 bits wide, 
providing a 64K I/O address space with 8-bit and 16-bit data transfers. 


Interrupt lines support signalling between agents on the bus and the 
Primary Requesting Agent. 


The DMA capability allows 8-bit or 16-bit data transfer between memory 
and I/O agents without direct intervention of the CPU on the Primary 
Requesting Agent. 


The Primary Requesting Agent refreshes all agents with refresh cycles. The 
Primary Requesting Agent will initiate refresh cycles at the request of a 
Secondary Requesting Agent that is in control of the bus in order to 
maintain integrity of the data in system DRAM. 


Multiple agent support is provided. The ISA Bus supports up to five agents, 
including one Primary Requesting Agent and up to a total of four 
Secondary Requesting Agents and Replying Agents. A Primary 
Requesting Agent (the 300SX board itself) is required in all 
implementations. Secondary Requesting Agents and Replying Agents are 
strictly optional. 


SIGNAL GROUPS 


The ISA Bus contains seven groups of signals: address, data, cycle control, 
central control, interrupt, direct memory access (DMA), and power. The bus 
signals can support a Primary Requesting Agent, which has an onboard DMA 
controller, optional Secondary Requesting Agents, and Replying Agents 
providing DMA or I/O memory expansion. The input and output direction 
designations for each signal are referenced to the Primary Requesting Agent. 


Intel386™ MicroComputer Model 300SX Board 


Intel ISA Bus Interface 





9.4.1 Address Signal Group 


The address signal group consists of signals driven by the Requesting Agent in 
order to specify both the address and data transfer width. - 


A(19:0) (I/O) 


The A(19:0) (Address) bus signals are latched outputs driven by a Requesting 
Agent. They represent the least significant 20 bits of a positive logic binary 
number, defining a 1M address space. A(19:0) become valid when BUSALE is 
asserted, and they may be latched by Responding Agents on the falling edge of 
BUSALE. 


A(19:16) are driven low during I/O cycles. During refresh cycles, the Primary 
Requesting Agent drives A(7:0) with the DRAM row address to be refreshed and 
drives A(19:8) to 0. 


LA(23:17) (I/O) 


The LA(23:17) (Unlatched Address) bus signals are driven by a Requesting 
Agent. These signals are not latched by the Primary Requesting Agent. 
However, they are valid when BUSALE is asserted, and they may be latched on 
the falling edge of this signal. LA(23:17) represent bits 17 through 23 of the 
memory address presented on the bus. LA(23:17) should be used by 16-bit 
Replying Agents in generation of SRDY*, MCS16*, and |OCS16*. 


The Requesting Agent drives LA(23:17) during any transfer cycle. LA(23:17) are 
driven to 0 during I/O cycles. During Secondary Requesting Agent cycles, 
LA(23:17) must be valid throughout the entire transfer cycle, and BUSALE is 
asserted by the Primary Requesting Agent. 


The Primary Requesting Agent drives LA(23:17) to 0 during refresh cycles. 
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SBHE* (I/O) 


SBHE* (System Bus High Enable) is asserted by a Requesting Agent to indicate 
a transfer of data on lines D(15:8). 


BUSALE (O) 


BUSALE (Bus Address Latch Enable) is an address strobe driven by the Primary 
Requesting Agent. LA(23:17) are valid when BUSALE is asserted, and they may 
be latched on the falling edge of BUSALE. A(19:0) are latched by the Primary 
Requesting Agent on the leading edge of BUSALE during bus cycles initiated by 
the PRA. 


All agents must be level sensitive with respect to BUSALE. This means that 
although the address signal group signals or decodes generated from them may 
be latched by agents on the falling edge of BUSALE, all agents must monitor the 
address signal group signals whenever BUSALE is asserted. This is especially 
important during DMA cycles, Secondary Requesting Agent cycles, and refresh 
cycles. 


For all DMA controller cycles (including Secondary Requesting Agent cycles), the 
Primary Requesting Agent asserts BUSALE to allow the LA(23:17) address to 
“pass through" transparent address latches to the bus. 


AEN (0) 


AEN (DMA Address Enable) is asserted by the Primary Requesting Agent when 
its CPU is in the hold mode and its DMA controller has control of the bus. AEN is 
negated by the Primary Requesting Agent when its CPU is in control of the bus or 
when the DMA controller has granted the bus to a Secondary Requesting Agent. 
When AEN is asserted, all agents other than the Primary Requesting Agent must 
tri-state their Address Signal Group and Cycle Control Signal Group outputs to 
the ISA Bus. 


During DMA cycles, the validity of LA(23:17),SA(19:0) is indicated by the 
assertion of both AEN and BUSALE. 
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9.4.2 


9.4.3 


Secondary Requesting Agents cannot conduct DMA cycles because only the 
Primary Requesting Agent can drive the DACKn* and AEN signals. 


Data Signal Group 


The data signal group consists of one set of 16 data bits. Data transfers may 
occur over either of the two bytes independently of one another. 


D(15:0) (I/O) 


On the D(15:0) (Data Bus), D15 is the most significant bit and DO is the least 
significant bit. All 8-bit Replying Agents must connect only to the least significant 
eight data lines, D(7:0). To support communication of 8-bit Replying Agents to 
16-bit Requesting Agents, both data swapping and transfer reformatting are 
supported by the Primary Requesting Agent. During odd-byte transfers between 
a 16-bit Requesting Agent and an 8-bit Replying Agent, the PRA drives the data 
appearing on D(7:0) onto D(15:8). Transfer reformatting is accomplished by the 
Primary Requesting Agent when it formats 16-bit accesses to 8-bit Replying 
Agents as two consecutive 8-bit ISA Bus cycles. 


The Primary Requesting Agent tristates D(15:00) during refresh operations. 


Cycle Control Signal Group 


The cycle control signals control the duration and type of cycles. The group 
consists of six command signals, two ready signals, and three signals which 
specify the cycle type. 


The command signals define the address space (memory or I/O) and the data 
direction (read or write). The ready signals modify the command pulse widths to 
lengthen or shorten the default cycle timings. 
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MRDC*, MEMR* (I/O) 


MRDC* (Memory Read command) is asserted when the Requesting Agent is 
ready for a Replying Agent to drive the data bus with the contents of the memory 
location specified by LA(23:17), A(19:0). MEMR* is identical in function to 
MRDC%, except that it is asserted only when the memory read access falls below 
1M. Eight-bit agents will receive only MEMR*. 


The refresh circuitry on the Primary Requesting Agent asserts MEMR* and 
MRDC* during refresh cycles initiated by a Secondary Requesting Agent in 
control of the bus. 


MEMW*, MWTC?* (I/O) 

MEMW* (Memory Write command) is asserted during a write cycle when the 
Requesting Agent is driving the data bus. MWTC* is identical in function to 
MEMW*, except that it is asserted only when the memory write access falls below 
1M. Eight-bit agents receive only MWTC*. 

IORC* (I/O) 

IORC* (I/O Read command) is asserted when the Requesting Agent is ready for 
a Replying Agent to drive the data bus with the data available from the I/O port 
specified by A(15:0). 

IOWC* (I/O) 

lOWC* (I/O Write command) is asserted during an I/O write cycle when the 


Requesting Agent is driving the data bus and it is negated when a Replying 
Agent must clock the data into the I/O port specified by A(15:0). 
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MCS16* (1) 


MCS16* (16-bit Memory Cycle Select) is asserted by a 16-bit memory agent to 
indicate to the Requesting Agent that a 16-bit cycle may be executed. Replying 
Agents generate MCS16* based on a decode of LA(23:17). Timing 
requirements placed on MCS16* prevent use of the memory command signals 
MEMR*/MRDC* and MEMW*/MWTC*% in generation of MCS16*. The 
Requesting Agent ignores MCS16* on I/O cycles. 


1OCS16* (I) 


IOCS16* (16-bit I/O Cycle Select) is asserted by a 16-bit I/O agent to indicate to 
the Requesting Agent that a 16-bit cycle may be executed. Replying agents 
generate |OCS16* based on a decode of A(15:0). Timing requirements placed 
on lOCS16* prevent use of IOWC* and IORC* in generation of |OCS16*. The 
Requesting Agent ignores |OCS16* on memory cycles. 


IOCHRDY* (1) 


IOCHRDY* (I/O Channel Ready) is an asynchronous ready signal from a 
Replying Agent. It is negated to force the Requesting Agent to lengthen the bus 
cycle by inserting an integral number of wait states (one-half of an ISA Bus 
SYSCLK period, or 62.5 ns). IOCHRDY* must not be negated for longer than 
15 us. IOCHRDY* is ignored by the Primary Requesting Agent during zero-wait 
state cycles. 


SRDY* (I) 


SRDY* (Synchronous Ready) is asserted by the Replying Agent to terminate the 
current bus cycle without any further wait states. The absolute minimum 
command pulse width is nominally 1 SYSCLK period (125 ns) in length, and is 
known as a zero-wait state cycle. Secondary Requesting Agents are not required 
to support SRDY*. 
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MEMREF* (I/O) 


MEMREF* (Refresh) is asserted during a DRAM refresh cycle. Only memory 
read cycles may occur while MEMREF* is asserted. The address present on 
A(7:0) is used by memory agents as the address of the row to be refreshed. 


A Secondary Requesting Agent may, if it is the current bus owner, tri-state its 
address, command, and data drivers and assert MEMREF* to force the PRA to 
conduct a refresh cycle. Secondary Requesting Agents must do this every 15 ys 
if they retain ownership of the bus, or the contents of the system DRAM will be 
lost. When a refresh cycle is initiated in this manner, the PRA will assert A(7:0) 
and MEMR*/MRDC*. 


Refresh cycles occur at a period of 15 us. Each of the 256 possible refresh 
addresses must, therefore, be refreshed at least once every 4 ms. 


Central Control Signal Group 


The central control group consists of special timing, control, and error signals. 
The function of these signals is as follows. 


SECMAST* (I) 


SECMAST* (Secondary Master) is asserted by a Secondary Requesting Agent to 
gain control of the bus after receiving the appropriate DACKn* from the Primary 
Requesting Agent. When SECMAST* is asserted, all other Requesting Agents 
must tri-state their address, data, and control signals. After SECMAST* is 
asserted, the Secondary Requesting Agent must wait at least one SYSCLK 
period before driving the address and data group signals, and it must wait at 
least two SYSCLK periods before driving the cycle control group signals. If 
SECMAST? is asserted for longer than 15 pus, the SRA must initiate refresh cycles 
to maintain DRAM data integrity. Note that only DMA channels programmed in 
the cascade mode may be used by SRA’s wishing to gain control of the bus. 
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IOCHCK* (1) 


IOCHCK* (I/O Channel Check) may be asserted by any agent to signal an error 
condition that cannot be corrected, such as a memory parity error. IOCHCK* 
must be asserted for at least 15 ns for the Primary Requesting Agent to 
recognize that an error condition has occurred. 


RSTDEV (0) 


RSTDEV (Reset Drive) is asserted by the Primary Requesting Agent to initialize all 
agents on the ISA Bus after powerup or during a low-voltage condition. 


SYSCLK (O) 


SYSCLK (System Clock) has a frequency of 8 MHz with a 50% duty cycle, and it 
is driven by the Primary Requesting Agent. Bus cycle times are directly 
proportional to the clock period. All synchronous signals on the ISA Bus are 
synchronous to SYSCLK. 


Bus cycles are lengthened by IOCHRDY* or shortened by SRDY* in integer 
multiples of one-half the SYSCLK period. For example, SRDY* could be asserted 
during a 16-bit cycle to reduce the command pulse width to 1.5 SYSCLK periods. 
Likewise, IOCHRDY* could lengthen a 16-bit cycle to N + 2.5 SYSCLK periods, 
where N is the number of wait states that the accessed device requests. Since 
the DMA controller operates off of a 4 MHz clock, DMA cycles are extended in 
multiples of 2 SYSCLK periods. 


840SC (0) 


840SC (Oscillator Output) is a 50-percent duty cycle clock signal with a 
frequency of 14.31818 MHz. 84OSC is not synchronous to either SYSCLK or any 
other signals on the ISA Bus; therefore, it must not be used in applications which 
require synchronization to the bus. 
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9.4.5 


9.4.6 


9-12 


Interrupt Signal Group 


The interrupt signal group consists of a set of signals that can be used by a 
Replying Agent to obtain interrupt service from a Requesting Agent. 


IRQ (D 


Asserting the IRQ(15,14,12:09,07:03) (Interrupt Request) line requests an 
interrupt. The line must remain asserted until the interrupt is acknowledged by 
the appropriate software interrupt service routine. 


Direct Memory Access Signal Group 


These signals control direct memory access service and transfer of bus 
ownership from the Primary Requesting Agent to a Secondary Requesting Agent. 


DRQ (1) 


DRQ(7:5,3:0) (Direct Memory Access Request) signals are asynchronous 
channel requests used to gain either DMA service or control of the bus from the 
Primary Requesting Agent. DMA service or bus control can be attained by 
asserting a DRQ line and keeping it asserted until the corresponding DACK* line 
is asserted by the Primary Requesting Agent. When Secondary Requesting 
Agents wish to gain control of the bus, they must only use DMA channels that 
have been programmed to operate in the cascade mode. 


DACK* (O) 
DACK(7:5,3:0)* (DMA Request Acknowledge) lines are driven by the Primary 
Requesting Agent to acknowledge DMA requests DRQ(7:5,3:0). I/O repliers use 


DMA acknowledge signals for address selection during DMA cycles when AEN is 
asserted. 
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TC (O) 


TC (Terminal Count) is asserted by the Primary Requesting Agent when any one 
of its DMA channels has reached its terminal count, signalling the end of the pre- 
programmed DMA transfer. 


9.4.7 Power Signal Group 


The ISA Bus provides DC power at +5V, —5V, +12V, —12V, and OV (Ground). 


+5 VOLTS 


Three pins supply current for 16-bit agents. Two (2) pins supply current for 8-bit 
agents. 


—5 VOLTS 


One pin supplies current. 


+12 VOLTS 


One pin supplies current. 


—-12 VOLTS 


One pin supplies current. 
0 VOLTS (GROUND) 


Four pins provide a return path for the currents supplied by the other power pins 
for 16-bit agents. Three pins provide this return path for 8-bit agents. 
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9.5 ISA BUS PIN ASSIGNMENTS 


Tables 9-2 and 9-3 list the pin assignments for the ISA bus 8-bit and 16-bit 
connectors, respectively 


Table 9-2. ISA Bus 8-bit Connector Pin Assignments 


Ground IOCHCK 

RSTDEV DO7 
+ 5V Do6 
IRQ09 DO5 
- 5V D04 
DRQ2 DO3 
-12V DO2 
SRDY DO1 
+12V DOO 

Ground IOCHRDY* 
MEMW* AEN 
MEMR* A19 
|JOWC* A18 
IORC* Ai7 
DACK3* A16 
DRQ3 A15 
DACK1* A14 
DRQ1 A13 
MEMREF* Al2 
SYSCLK A141 
IRQO7 A10 
IRQ06 AOQ 
IRQ05 AO8 
IRQ04 AO7 
IRQ03 AO6 
DACK2* AO5 
TC A04 
BUSALE AO3 
+ 5V AQ2 
840SC AO1 
Ground AOQO 
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Table 9-3. ISA Bus 16-bit Connector Pin Assignments 


MCS16* 
1OCS16* 
IRQ10 
IRQ11 
IRQ12 
IRQ15 
IRQ14 
DACKO* 
DRQO 
DACK5* 
DRQ5 
DACK6* 
DRQ6 
DACK7* 
DRQ7 
+5V 
SECMAST* 
Ground 
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External Interfaces 


10.1 INTRODUCTION 


This chapter describes the external interfaces found on the 300SX board. 


10.2 PARALLEL PORT CONNECTORS 


The parallel printer port, at connector J1, provides a one-way interface to a 
printer. J1 is a 25-pin D-subminiature female connector. J11, a2 x 13 header, is 
provided for connecting to ribbon cables. Table 10-1 lists the pinouts for Ji and 
Table 10-2 lists the pinouts for J11. 
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Table 10-1. J1 Parallel Port Connector Pinouts 


ee 


STROBE* 

PRTDO Data bit 0 
PRTD1 Data bit 1 
PRTD2 Data bit 2 
PRTD3 Data bit 3 
PRTD4 Data bit 4 
PRTD5 Data bit 5 
PRTD6 Data bit 6 
PRTD7 Data bit 7 
GACK* Acknowledge 
PPBUSY 

PE Paper end 
SLCT Select 
AUTOFDT* Auto feed 
PPERROR* 

INIT* 

SLCTIN* Select input 
Ground 


1 
2 
3 
4 
5 
6 
7 
8 
9 
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Table 10-2. J11 Parallel Port Connector Pinouts 


STROBE* 

AUTOFDT* Auto feed 
PRTDO Data bit 0 
PPERROR* 

PRTD1 Data bit 1 
INIT* 

PRTD2 Data bit 2 
SLCTIN* Select 
PRTD3 Data bit 3 
Ground 

PRTD4 Data bit 4 
Ground 

PRTD5 Data bit 5 
Ground 

PRTD6 Data bit 6 
Ground 

PRTD7 Data bit 7 
Ground 

GACK* Acknowledge 
Ground 

PPBUSY 

Ground 

PE Paper end 
Ground 

SLCT Select 
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10.3 SERIAL PORT CONNECTORS 


Connectors J2A and J2B provide signals for serial I/O ports COM1 and COM2. 
COM1 signals connect to the DB9 RS-232 male connector at J2B. COM2 
signals connect to the DB9 RS-232 male connector at J2A. COM1 and COM2 
signals are also available at J13, a2 x 13 header. Table 10-3 lists the pinouts for 
the J2A and J2B connectors and Table 10-4 lists the pinouts for J13. 


Table 10-3. J2A and J2B Serial Port Connector Pinouts 


Carrier detect 
Receive data 
Transmit data 
Data terminal ready 





a] 
— 
=) 
















Data set ready 
Request to send 
Clear to send 
Ring indicator 






OMANOOARWN— 
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Table 10-4. J13 Serial Port Pinouts 


ee ee 


DCD1 Carrier detect (COM1) 
DSR1 Data set ready (COM1) 
RXD1 Receive data (COM1) 
RTS1 Request to send (COM1) 
TXD1 Transmit data (COM1) 
CTS1 Clear to send (COM1) 
DTR1 Data terminal ready 


(COM1) 


Ri Ring indicator (COM1) 
Ground 

DCD2 Carrier detect (COM2) 
DSR2 Data set ready (COM2) 
RXD2 Receive data (COM2) 
RTS2 Request to send (COM2) 
TXD2 Transmit data (COM2) 
CTS2 Clear to send (COM2) 
DTR2 Data terminal ready 


(COM2) 


Rl2 Ring indicator (COM2) 
Ground 





10.4 KEYBOARD INTERFACE CONNECTOR 


The keyboard interface connects to a 5-pin DIN connector at J8B. Table 10-5 
lists the pinout of the J3B connector. 


Table 10-5. J3B Keyboard Connector Pinouts 


+KBD CLK 





+ KBD DATA 


Reserved 


Ground 


+ 5VDC (fused) 





Frame ground 
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10.5 MOUSE INTERFACE CONNECTOR 


The mouse interface connects to a 6-pin mini-DIN connector at J4. Table 10-6 
lists the pinouts of the J4 connector. 


Table 10-6. J4 Connector Pinouts 


Data 
Reserved 


Ground 
+5VDC (fused) 
Clock 
Reserved 





10.6 VIDEO INTERFACE CONNECTORS 


The 300SX board has two video interface connectors, J5 and J6. J5 is a 15-pin 
female connector intended for use with an analog (VGA) monitor. J6 is a 9-pin 
female connector intended for use with a digital (TTL) monitor. Table 10-7 lists 
the pinouts of the J5 connector. Table 10-8 lists the pinouts of the J6 connector. 


==> NOTE 
Pin one of the J5 connector is located in the upper left-hand corner of the 
connector. Pin 15 is at the lower right-hand corner. 
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Table 10-7. J5 Video Connector Pinouts 


Red video 

Green video 

Blue video 

Monitor identification bit 2 
Ground 

Red return (ground) 
Green return (ground) 
Blue return (ground) 

Key position (no pin) 
Sync return (ground) 
Monitor identification bit 0 
Monitor identification bit 1 
Horizontal syne 

Vertical sync 

Not used 


1 
2 
3 
4 
5 
6 
7 
8 
9 





=> NOTE 
Monochrome video displays use green video for all video input and ignore 
red and blue video. 


Table 10-8. J6 Video Connector Pinouts 


Function 


Ground 
Red video 
Intensified red video 
Intensified green video 
Intensified blue video 
Green video 

Blue video 

Horizontal sync 
Vertical sync 





s 
— 
=} 
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10.7 POWER SUPPLY CONNECTOR 


The 12-pin connector (J12) on the board (see Figure 10-1) distributes power to 
the board components and the four expansion slots. 


Pin 


SYSRST* 
+5V 
+12V 
-12V 
Ground 
Ground 
Ground 
Ground 
-5V 
+5V 
+5V 
+5V 


Oo DOAN DA FWD 


a ees 
yo += Oo 


A10042 


Figure 10-1. J12 Power Supply Connector 
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10.8 FLOPPY DISK INTERFACE CONNECTOR 


Table 10-9 lists the pinouts for the J18 floppy disk interface connector. 


Table 10-9. J18 Floppy Disk Interface Connector Pinouts 


ee 


GROUND Ground 

Head Load 

Ground 

No connect 

Ground 

No connect 
GROUND Ground 
INDEX* Beginning of track 
GROUND Ground 
MOTENA* Motor Enable A 
GROUND Ground 
DRVSELB* Drive Select B 
GROUND Ground 
DRVSELA* Drive Select A 
GROUND Ground 
MOTENB* Motor Enable B 


OANDOAA WN — 


GROUND Ground 


DIR* Direction select 
GROUND Ground 

STEP* Motor step 
GROUND Ground 
WRDATA* Write data strobe 
GROUND Ground 
FLPYWE* Floppy disk write enable 
GROUND Ground 
TRACKO* Track O indicator 
GROUND Ground 

WP* Write protect 
GROUND Ground 
RDDATA* Read data strobe 
GROUND Ground 

HDSEL* Head Select 
GROUND Ground 
DSKCHNG* Drive door open 
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10.9 FIXED DISK INTERFACE CONNECTOR 


Table 10-10 lists the pinouts for the J19 fixed disk interface connector. 


Table 10-10. J19 Fixed Disk Interface Connector Pinouts 


HOST RESET* Reset signal from CPU 
GROUND Ground 

HOST DATA 7 Data bit 7 

HOST DATA 8 Data bit 8 

HOST DATA 6 Data bit 6 

HOST DATA 9 Data bit 9 

HOST DATA 5 Data bit 5 

HOST DATA 10 Data bit 10 

HOST DATA 4 Data bit 4 

HOST DATA 11 Data bit 11 

HOST DATA 3 Data bit 3 

HOST DATA 12 Data bit 12 

HOST DATA 2 Data bit 2 

HOST DATA 13 Data bit 13 

HOST DATA 1 Data bit 1 

HOST DATA 14 Data bit 14 

HOST DATA 0 Data bit 0 

HOST DATA 15 Data bit 15 
GROUND Ground 

KEY No connection 
HOST IO CH RDY* /O channel ready 
GROUND Ground 

HOST !OW* VO write 
GROUND Ground 

HOST IOR* V/O read 
GROUND Ground 

HOST IOCHRDY* VO channel ready 
HOST ALE Address latch enable 
RESERVED No Connection 
GROUND Ground 

HOST IRQ14 IRQ14 

HOST lO CS16* Drive register enabled 
HOST ADDR 1 Address bit 1 
RESERVED No connection 
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Table 10-10. J19 Fixed Disk Interface Connector Pinouts (continued) 


HOST ADDR 0 Address bit 0 
HOST ADDR 2 Address bit 2 


HOST CSO* Reg. access chip select 0 
HOST CS1* Reg. access chip select 1 
DISK ACTIVE* Disk activity indicator 
GROUND Ground 





10.10 FRONT-PANEL CONNECTORS 
The system board has three connectors providing signals for front panel 
indicators. The following list defines the function of each connector: 


e J20 connects to the front panel reset button. 
e@ J22 provides the signal for the fixed disk drive access indicator. 


e@ J24 supplies the signal for the power-on indicator. 


10.11 SPEAKER INTERFACE 


A 74F125 high current analog driver provides audible tone generation for the 
speaker. The 74F125 uses an OSC signal derived from a counter on the 8254 
programmable interval timer (PIT) module to drive the SPKOUT signal. The OSC 
signal is gated on and off by bit O (ENABLE SPEAKER) of port 61H. Bit 1 
(SPEAKER DATA) supplies the data for sounding the speaker. A 1 x 4 speaker 
header (J21) provides the connection between the speaker and the system (refer 
to Table 10-11). 
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10.12 


10.13 


10-12 


Table 10-11. J21 Speaker Header Pinouts 


Signal/Function 


SPKOUT speaker drive out 


Key (pin missing) 
Ground 
+5VDC 





BATTERY CONNECTOR 


The system board includes a two connectors (J23 and J25) for installing 
batteries. The batteries backup CMOS RAM to retain system configuration and 
password information when power is removed. These two connectors provide 
the identical function; use J23 if the battery is mounted near the front of the board 
and J25 if the battery is mounted near the back of the board. 


KEYLOCK INTERFACE 


The keylock interface lockouts all data from the keyboard. The keyboard is 
locked out anytime the controller receives the KEYLOCK™ signal. A 1 x 5 keylock 
header (J24) provides the connection between the system and the controller (see 
Table 10-12). J24 also connects to the power-on indicator LED mentioned 
above. 


Table 10-12. J24 Keylock Header Pinouts 


Signal/Function 


Power for LED power-on light 


Key (pin missing) 
Ground 
KEYLOCK* 
Ground 
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Power-on 
Self Test and Setup 


11.1 INTRODUCTION 


This chapter describes the Power-on Self Test (POST), which executes 
automatically each time a 300SX system is booted, and the Setup program. 
Both the POST and the Setup program are stored in ROM on the 300SX board. 
This chapter assumes that the 300SX board has been correctly integrated into a 
computer system environment with all necessary I/O devices connected, 
peripheral devices installed, and configuration performed. 


11.2 POWER-ON SELF TEST 
Each time the system is turned on or reset, the POST runs automatically and 
checks the CPU, keyboard, video display, memory, and most onboard peripheral 
devices. 
During the POST memory test, the amount of memory being tested is displayed 
on the screen. Depending on the amount of extended memory installed, the 
POST memory test takes 3 to 15 seconds to complete. 


During a soft boot, the system executes all POST tests except memory. 
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When POST is complete the system beeps once, if no configuration errors are 
detected, and displays a message similar to the following : 


Phoenix 80386 ROM BIOS PLUS Version x.xx yy FOB 
Copyright (c) 1985-1989 Phoenix Technologies Ltd. 
All Rights Reserved 


640K Base Memory, 03072K Extended 


If configuration errors are detected, the system beeps twice and displays the 
following message: 


Invalid configuration information - 
please run the SETUP program 
Strike the F1 key to continue 


==> NOTE 
It is normal for this message to appear the first time you start the system. 











If you press [Ei] to continue, the system will operate correctly, but not at full 
potential. 
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11.3 SETUP PROGRAM 


The Setup program stores system configuration settings in the battery-backed 
memory of the CMOS real-time clock chip. You can change system settings at 
any time by running the Setup program. The stored information includes the 


following: 
@ Date and time 
e@ Number and capacity of floppy disk drives 
@ Number and type of fixed disk drives 


Amount of base memory 

Amount of extended memory 

Availability and type of primary video display controller 
Availability of keyboard 

CPU speed 

Availability of numeric coprocessor 

Shadow or do not shadow the system BIOS and video BIOS 
Shadow or do not shadow the offboard video BIOS 
Enable/Disable onboard winchester and floppy disks 
Enable/Disable COM1, COM2, LPT1, and LPT2 

Set the power-on password 

Enable/disable console redirection 


Enable/disable rolled memory 
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When the system boots, the POST checks the stored Setup information against 
the hardware configuration. If the data does not agree, the POST displays an 
invalid configuration message. If such a message appears, you can run Setup to 
enter the correct configuration parameters. 


The Setup program performs the following operations: 


e Displays date, time, and current values for system options. 


e@ Allows you to accept current (default) values or enter different values for 
time, date, and system options. 


e@ Provides instructions on booting the system so new settings take effect. 


11.4 RUNNING THE SETUP PROGRAM 


The Setup program is permanently stored in ROM, and can be running with or 
without an operating system present. 


To run Setup, wait for POST to complete (you'll hear a short beep), then 
immediately press [ctl] + [At] + [irs]. 

















The Setup program starts by displaying a screen similar to that shown in Figure 
11-1. The screen shows the current settings for the system. Because it reflects 
the exact configuration of your system, the actual display may not match this 
example. 
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System Configuration Setup Version x.xx 02 


Time: 08:20:20 

Date: Mon Jul 10, 1989 
Floppy disk A: 3.5 Inch, 1.44 MB 
Floppy disk B: Not Installed 
Hard Disk 1: Type 49 


Cyl Hd Pre LZ Sec Size(MB) 
965 5 -1 965 17 40 


Hard Disk 2: Not Installed 
Base Memory: 640 KB 
Extended Memory: 1024 KB 
Display: VGA/EGA 
Keyboard: Installed 

CPU Speed: Fast 
Coprocessor: Not Installed 


PgDn for advanced options. Up/Down Arrow to select. Left/Right Arrow to change. 
F10 to exit and save changes. Esc to reboot for changes to take effect. 


Figure 11-1. Setup Screen 1 








To change options, use the [ft] or [] key to move the cursor to a selected option. 
(The cursor moves only to the options that can be changed.) Change the 
selected option by pressing the [€] or [5] key. Each time you press one of these 
keys, the Setup program displays one of the possible values for the selected 
option. You cannot set the base memory, extended memory, or disk parameters 
using the [<] or [6] key. Instead, you must enter the numeric values using the 
number keys at the top of the keyboard. If you enter an incorrect number, you 
can correct the entry by using the [Backspace] key. The fixed disk parameter table 
can be displayed by selecting "Hard Disk 1" or "Hard Disk 2" and pressing the [Fi] 
key. 
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The screen shown in Example 1 is the first of three screens displaying the current 
settings for the system. Press the key to view the second Setup 
screen. 








When you finish setting options, exit Setup by pressing the [E19] key or the [Esc] 
key. You can exit Setup from either screen. 





Press to exit the Setup program without booting the system. Changes are 
saved, but only the date and time information take effect. The other changes 
take effect when the system boots. Press the [Ese] key to save the Setup changes 
and boot the system. 





Moving Through Setup Screen 1 


Make sure the first Setup screen is displayed (refer to Figure 11-1). If it is not, 
press the key. 


SETTING SYSTEM TIME 








If the time is incorrect, use the [ft] or [i] key to move the cursor to the time option 
fields on the Setup screen. 


Time: 08:20:20 


The time option contains three fields: hours, minutes, and seconds. Set the 


hours and minutes fields using the [<] or E] key. Pressing the gray [-] key moves 
the clock forward. Pressing the gray [E] key moves the clock backward. Holding 
down the [<] or [5] key causes the value to increase or decrease continuously. 
Set the hour field first and then press the [i] key to move to the minutes field. Set 
the minutes field using the [<] or [5] key. Reset the seconds field to 00 by 


selecting this field and pressing either the [4] or [Ej key. 
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SETTING SYSTEM DATE 


If the date is incorrect, use the [f] or [4] key to move the cursor to the date option 
fields on the Setup screen. 





Date: Tue May 23, 1989 


The date option contains four fields: day of the week, month, day of the month, 
and year. You can set all fields except the day of the week. When any of the 
other three fields are changed, the Setup program automatically resets the day of 
the week accordingly. 











Increase or decrease the date fields using the [<] or E] key. When one field is 


set, press the [f] or fi] key to move to a different field. 




















SETTING FLOPPY DISK DRIVE TYPES 


The Setup program maintains information about two floppy disk drives (drive A 
and drive B). If the information about either of these floppy disk drives is 
incorrect, use the [f] or [i] keys to move the cursor to the appropriate field. 














7 





Floppy disk A: 3.5 Inch, 1.44 MB 
Floppy disk B: Not Installed 


Change the floppy disk options by pressing the [€] or [E] keys. The allowable 
floppy disk options are as follows: 


3.5 Inch, 1.44 MB 
3.5 Inch, 720 KB 
5.25 Inch, 1.2 MB 
5.25 Inch, 360 KB 
Not Installed 


If only one floppy disk drive is installed, it is always drive A. Set drive B to Not 
Installed. You cannot change the individual fields within the options. 
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SETTING FIXED DISK DRIVE TYPES 


The Setup program maintains drive type information for two fixed disk drives 
(drive 1 and drive 2). 


Hard Disk 1: Type 49 
Hard Disk 2: Not Installed 


If the drive type for either of these disks is incorrect, use the [ft] or [t] key to move 
the cursor to the appropriate field. 





If you know the drive type associated with the fixed disk, press the [<] or [5] key 
until the drive type appears on the screen. 


The fixed disk parameter table can be displayed by selecting "Hard Disk 1" or 
"Hard Disk 2" and pressing the [Fi] key. Compare this list with the specifications 
of your disk drive to determine the correct drive type. 





WY caution 
It is essential to specify the correct fixed disk drive type because the Setup 
program cannot independently verify this information. Specifying an 
incorrect drive type may damage the disk. 


If the list does not include the drive type in the system, choose the 
user-configurable disk type. Set the number of cylinders, number of heads, and 
disk capacity parameters to match the specifications of the fixed disk. 


If only one fixed disk drive is installed, it is always drive 1. 


SETTING EXTENDED MEMORY 


Extended memory is RAM above 1024K (1M). The first 1M of memory is used for 
base and dedicated RAM. To compute extended memory, this amount must be 
subtracted from the total amount of onboard RAM in the system. 


If the POST indicates "Invalid configuration information," when Setup is executed, 


Setup will attempt to correct the error if it is due to an invalid memory 
configuration. 


Intel886™ MicroComputer Model 300SX Board 


Power-on Self Test and Setup 


SETTING VIDEO DISPLAY CONTROLLER TYPE 


The type of video display controller installed in the system must be correctly 
specified for POST to function correctly. If the information listed on the Setup 
screen is incorrect, use the [ft] or [4] key to move the cursor to the display field. 

















Display: VGA/EGA 
Change the display options by pressing the [<] or [-] Key. 


==> NOTE 
Set the display to VGA/EGA even if another controller board is present and 
designated as the primary controller. This enables the POST to properly 
configure the onboard VGA controller. 


The following video display controller selections are available: 


VGA/EGA video graphics array (VGA) or enhanced graphics adapter 
(EGA) 

CGA40 color/graphics adapter in 40-column mode 

CGA80 color/graphics adapter in 80-column mode 

MONO monochrome video display controller 


Not Installed No display attached. Use this setting to suppress errors 
relating to the video display. This permits systems such as 
network servers to operate without video displays. Ifa 
display is attached, it will operate in the CGA80 mode. 
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SETTING KEYBOARD AVAILABILITY 


The presence or absence of a keyboard must be correctly specified for the POST 
to function correctly. If the information listed on the Setup screen is not correct, 
use the [ft] or [i] key to move the cursor to the display field. 





Keyboard: Installed 


The keyboard option can be changed by pressing the [<] or [] key. The 
following choices are available: 


Installed Keyboard attached. 


Not Installed Keyboard not present. Use this setting to prevent the POST 
from pausing when it detects the absence of the keyboard 
and reports an error. This permits systems such as network 
servers to operate without keyboards. If a Keyboard is 
attached, it will operate correctly. 


SETTING CPU SPEED 


The CPU speed setting determines the speed used by the system each time you 
turn on the power. If the information listed in the Setup screen is not correct, use 
the [ft] or ft] key to move the cursor to the display field. 











CPU Speed: Fast 





Change the CPU speed option by pressing the 
choices are available: 





| 





or [6] key. The following 








Fast Fast (16 MHz) is the normal setting for the CPU speed. 


Slow Slow (8 MHz) is used to reduce CPU speed to be 
compatible with some applications programs. If a program 
does not run correctly at 16 MHz, change the CPU speed to 
slow. 
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11.4.2 Moving Through Setup Screen 2 














Press the [Page Down] key. A screen display similar to the one shown in Figure 11-2 


appears. 


System Configuration Setup 
Additional Options 


Time: 
Date: 


Enter SETUP: 

Speaker: 

Onboard Video Controller: 
Onboard Video Display: 
Monochrome Startup Mode 
Video Timing Register Lock: 
Monitor Type 

Onboard Video BIOS Mapping: 
Onboard Peripherals: 


Password: 
Parallel Port: 


Serial Port 1: 
Serial Port 2: 


Console Redirection to COM1: 


08:20:20 
Mon Jul 10, 1989 


Pre-boot 

Enabled 

Primary 

VGA 

Color Mode (3+) 

Norma] 

VGA Display 

To EOOOOH 

Onboard floppy & 
winchester enabled 

Not Installed. Depress 
<cr> to enter 

LPT1 

COM1 

COM2 

Disabled COM2: 9600 Baud 


PgUp for main menu and PgDn for additional options. Up/Down Arrow to select. 


Left/Right Arrow to change. 
changes to take effect. 


Figure 11-2. Setup Screen 2 


F10 to exit and save changes. Esc to reboot for 


These options are preset to the recommended choice. In most cases they need 


not be changed. 
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ENTER SETUP 


Two options are available in the enter Setup selection. You can always enter 
Setup (from the DOS prompt) or from a pre-boot. Set either option using the [ff] 
or [i] key to move the cursor to the display field. 

















Enter SETUP: Pre-boot 


























Change the option by pressing the [<] or [5] key. 
SPEAKER 
To enable or disable the speaker, use the [ft] or [4] key to move the cursor to the 
display field. 
Speaker: Enabled 


Change the option by pressing the [€] or [5] key. 





ONBOARD VIDEO CONTROLLER 


Two options are available in the onboard video controller selection: primary and 
secondary. To change the onboard video controller option, use the [ft] or i] key 
to move the cursor to the display field. 




















Onboard Video Controller: Primary 


Change the option by pressing the [<] or ] key. 
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ONBOARD VIDEO DISPLAY 
The onboard video selection is used to set up the onboard video display 
controller. The following onboard video display controller options are available: 


Auto Automatic mode. In this mode the Setup program attempts 
to configure automatically. 


CGA Color/graphics adapter mode 

MGA Monochrome/graphics adapter mode 
EGA Enhanced graphics array mode 

VGA Video graphics array mode 


Change the option by pressing the [<] or E] key. 


MONOCHROME MONITOR STARTUP MODE 


This selection allows you to set the startup mode for a VGA monochrome monitor 
to monochrome or color (displayed as 64 shades of gray). To change the 
monochrome monitor startup mode option, use the [ft] or [i] key to move the 
cursor to the display field. 




















Monochrome Startup Mode: Color Mode (3+) 


Change the option by pressing the [<] or ] key. 
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VIDEO TIMING REGISTER LOCK 


This selection has two options: Normal and Protected. Normal allows programs 
to write data to the timing registers of the CRT controller while Protected inhibits 
programs from writing to the CRT controller registers. To change the video 
timing register lock option, use the [f] or [y] key to move the cursor to the display 
field, 





Video Timing Register Lock: Normal 


Change the option by pressing the [€] or [5] key. 





MONITOR TYPE 


This selection allows you to choose between three monitor types. You can select 
monochrome, color, or EGA. To change the monitor type option, use the [f] or 
key to move the cursor to the display field. 

















Monitor Type: EGA Display 
Change the option by pressing the [<] or [5] key. 





ONBOARD VIDEO BIOS MAPPING 


The Video BIOS is normally mapped to memory location EOQOOOH, however, some 
application programs require the Video BIOS to be located at COOOOH also. To 


change the onboard Video BIOS mapping option, use the [f] or [i] Key to move 
the cursor to the display field. 














Onboard Video BIOS Mapping: To EOQOOH 





Change the option by pressing the [«] or [5] key. 
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ONBOARD PERIPHERALS 





To enable or disable the onboard peripherals option, use the [f] or [] key to move 
the cursor to the display field. 











Onboard Peripherals: On-board floppy and winchester enabled 


Change the option by pressing the [<] or ] key. 





PASSWORD 


Set the system password by performing the following: 





1. Use the [f] or [tJ key to highlight the display field. 














2. Follow on-screen procedures. 


After validation, Setup stores the password in the RTC. 


PARALLEL PORT 


Three options are available in the parallel port selection: LPT1, LPT2, and 
Disabled. To change the parallel port option, use the [ft] or [i] key to move the 
cursor to the display field. 





Parallel Port: LPT1 





Change the option by pressing the [€] or [5] key. 
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SERIAL PORT 1 

Three options are available in the serial port 1 selection: COM1, COM2, and 
Disabled. To change the serial port 1 option, use the [f] or [i] key to move the 
cursor to the display field. 


Serial Port 1: COM1 
Change the option by pressing the [<] or I] key. 


SERIAL PORT 2 

Three options are available in the serial port 2 selection: COM1, COM2, and 
Disabled. To change the serial port 2 option, use the ff] or [i] key to move the 
cursor to the display field. 


Serial Port 2: COM2 











Change the option by pressing the 


(J 





or [5] key. 








==> NOTE 
Setup allows serial port 2 to be set to the same value as serial port 1. 
However, the POST will automatically change the serial port 2 setting to 
the opposite setting when the system is rebooted. 


CONSOLE REDIRECTION TO COM1: 


Three options are available in the console redirection to COM:1 selection. You 
can set COM1: at 9600 baud, 1200 baud, or disable COM1. You can also set 

COM2: using the same options. You can set any of the three options using the 
ft] or [uJ key to move the cursor to the display field. 





Console Redirect. to COM1: Disabled COM2:9600 Baud 





Change the option by pressing the [«] or [5] key. 











Intel386™ MicroComputer Model 300SX Board 


Power-on Self Test and Setup 


11.4.3 Moving Through Setup Screen 3 





Press the [Page Down] key. A screen display similar to the one shown in Figure 11-3 
appears. 


System Configuration Setup 
Additional Options 


Time: 08:20:20 

Date: Mon Jul 10, 1989 

Shadow BIOS ROM: System and on-board Video BIOS 
Base Memory Above 512K: Enabled 

Offboard Video Shadow: Disabled 

Memory Rol}: Enabled 


PgUp for main menu and PgDn for additional options. Up/Down Arrow to select. 
Left/Right Arrow to change. F10 to exit and save changes. Esc to reboot for 
changes to take effect. 


Figure 11-3. Setup Screen 3 


These options are preset to the recommended choice. In most cases they need 
not be changed. 


SHADOWING SYSTEM BIOS AND VIDEO BIOS 


The system board reserves an area of RAM for a copy of the system BIOS and 
video BIOS. This memory, called shadow memory, is write-protected and has 
the same addresses as the ROM locations. If you select the shadow option, the 
system copies the system BIOS and the video BIOS to this area and disables the 
ROM. System I/O performance increases significantly, because the information 
is maintained in fast RAM instead of ROM. 
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Setup Screen 3 presents the Shadow BIOS ROM option. It is recommended that 
you select the system and onboard video BIOS option. 


Shadow BIOS ROM: System and on-board video BIOS 


If the system and onboard video BIOS option is selected, the system copies both 
the system BIOS and video BIOS into their corresponding RAM locations on 
power up. Programs then access the information from the RAM copy. 


==> NOTE 
Some high resolution plug-in video display controllers do not work 
properly when Video BIOS shadowing is enabled. If you have a high 
resolution video display controller installed and you experience display 
problems, set the shadow option to disabled. 


BASE MEMORY ABOVE 512K 





To enable or disable the memory between 512K and 640K, use the [f] or [i] key 
to move the cursor to the display field. 











Base Memory Above 512K: Enabled 
Change the option by pressing the [&] or [5] key. 





OFFBOARD VIDEO SHADOW 





To enable or disable the offboard video BIOS shadow option, use the [ft] or [fy] key 
to move the cursor to the display field. 














Offboard Video Shadow: Disabled 


==> NOTE 
Enabling this option shadows the offboard video BIOS from COOOOH to 
DFFFFH not just from COOO0H to C8000H. Therefore, use this option with 
caution. 





Change the option by pressing the [€] or ] key. 
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MEMORY ROLL 

Enabling this option allows the system to add any memory not used for the 
shadowing function to end of extended memory. To enable or disable the 
memory roll option, use the [f] or fi] key to move the cursor to the display field. 


Memory Roll: Disabled 
Change the option by pressing the [+] or [5] key. 


11.5 EXITING THE SETUP PROGRAM 


When you finish setting system options, follow the instructions on the screen to 
exit the Setup program. 
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A.l SYSTEM BOARD SPECIFICATIONS 
e@ CPU: 386SX microprocessor 
@ Clock rate: 16 MHz 
e@ ISA Bus speed: 8 MHz 
e Datapath: 16 bits 


e Physical addressing: 16M 


Virtual addressing: 64 terabytes 


A.1.1 ROM 


e Size: 128K 


A.1.2 Onboard RAM 
e Base memory size: 2M 


e Base memory expandable to: 4M 
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A.1.3 


A.2 


A.2.1 


A.2.2 


Expansion Slots 


e@ Four 8- and 16-bit slots, Intel ISA standard 


300SX BOARD PHYSICAL CHARACTERISTICS 


Dimensions 


=> Note 
Figure A-1 shows the 300SX board dimensions. 


e Width: 12 inches (30.48 cm) 


Length: 10.0 inches (25.4 cm) 


Height: 0.75 inch (1.8 cm) 


Weight: 3.3 pounds (1.5 kg) 


Environment 
@ Operating temp: 0°C to 55° C (32°F to 131° F) 
e@ Storage temp: -40°C to 65° C (-40° F to 149° F) 
e@ Operating humidity: 20% to 80% RH 
e Storage humidity: 5% to 95% noncondensing 


@ Altitude: 10,000 feet (8048 m) maximum 
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12.0" 


Hole Diameter Legend 
O =0.156 
@ =0.147 A10011 


Figure A-1. Model 300SX System Board Dimensions 
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A-4 


BOARD POWER REQUIREMENTS 


The board requires the power consumption and current ratings listed in Table A-1 
for normal operation. 


Table A-1. Power Consumption 


+5V +5% 4A 
+12V +10%) =O0.1A 
-12V +10% 0.1A 





The 300SX board contains four 8- or 16-bit expansion slots. 


The maximum available +5V current allowable to any expansion slot depends 
upon the following parameters: 


@ The number of +5V pins in the slot providing current 

@ The power supply capacity 

e@ The current-carrying capability of the power connectors 

@ The power demands of both the board and all other slots in use 


@ The board circuit traces 


Each expansion slot +5V pin can carry a maximum of 3A. Table A-2 lists the 
current ratings for each slot type. 
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Table A-2. Maximum Current Ratings 


Slot Type Maximum Allowable Current Per Slot 


8-bit 6A (3A per pin with 2 pins) 
16-bit 9A (3A per pin with 3 pins) 


WY CAUTION 
The ISA bus connectors are limited to 3A per +5V pin maximum. The 
power supply connectors are limited to 5A per pin maximum. These 
limitations plus the maximum capacity of the power supply itself may be 
more restrictive than the current limitations of the pins/connectors and 
expansion slots. As an overall limitation, do not exceed 12A total when 
computing total +5V current drain for the system board. This avoids 
damage to the power supply and board. 





Table A-2 specifies the nominal current drain for various system board 
configurations. 


Table A-3. Maximum +5V Current Drain on 300SX Board 


Maximum 
+5V Current 
Required 


System board (2M onboard 
RAM, no numeric coprocessor, 
no expansion boards) 


387SX numeric coprocessor 
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System BIOS Specifications 





B.1 INTRODUCTION 


The BIOS is a software interface that isolates operating systems and application 
programs from specific hardware devices. BIOS routines allow assembly 
language programmers to do block and character-level operations without 
concern for device addresses or hardware operating characteristics. The BIOS 
also provides system services such as time-of-day and memory size information. 


This appendix provides a description of the BIOS routines. 


Intel386™ MicroComputer Model 300SX Board B-1 


System BIOS Specifications 


B.2 


B.3 


SYSTEM ID STRING 


The system BIOS reserves seven bytes starting at location FOO0:EDOO for an 
ASCII System Identification string. 


Table B-1. System ID String 


ASCII 
Byte Value | Function 







FOOO0:EDOO Constant 
FOO0:EDO1 Constant 
FOOO:EDO2 Constant 
FOQ00:EDO3 Constant 
FOO0:ED04 System type 


FOO0:EDO5 Board version 





NON-MASKABLE INTERRUPT (INT 02H) 


The system board and I/O channel parity error signals connect to the NMI pin of 
the CPU. If amemory parity error occurs, the hardware invokes this routine. The 
routine examines a register and ensures the reason for the interrupt is a memory 
parity error. If no memory parity error occurred, the routine returns to the 
interrupted operation. Some video controllers may make use of the NMI. The 
parity checking aspect is never impaired. Note that the I/O channel error and 
parity error sources of an NMI can be masked. 


Input: © None 


Output: Error message; system halts 
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B.5 


PRINT SCREEN (INT 05H) 


Invoking this routine prints the screen. The cursor position at the time this routine 
invokes is saved and restored upon completion. During execution of this routine, 
the PRINT SCREEN key is ignored. 


Input: None 


Output: Location 50:0H 
=0 Normal termination or print screen not busy 
=1 Print screen in progress 
= FFH Error during print screen 


SYSTEM TIMER H/W INTERRUPT (INT 08H) 


This interrupt occurs when channel zero of the system timer counts down to zero. 
The BIOS handler keeps a count of interrupts starting at power-on for use as a 
system clock. It also decrements the disk drive motor control counter and shuts 
off the drive when the counter expires. In addition, the BIOS handler invokes 

INT 1CH allowing a user routine to execute. 


Input: None 


Output: None 
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KEYBOARD H/W INTERRUPT (INT 09H) 

This interrupt occurs each time a key is pressed. The BIOS handler checks for 
certain special keys or combinations, such as CTRL, ALT, DEL or PAUSE and 
takes action if one occurs. Otherwise the key scan code and its ASCII value, if 


applicable, are moved into the keyboard buffer (provided enough space is 
available). 


Input: None 


Output: None 


DISK H/W INTERRUPT (INT 0EH) 
This interrupt occurs when the disk drive requires attention. During multi-sector 
transfers, the controller interrupts for each transfer. A completed operation also 


generates an interrupt. The BIOS handler sets bit 7 of the byte at 40:30H 
indicating an interrupt occurred. 


Input: None 


Output: None 


Intel386™ MicroComputer Model 300SX Board 


System BIOS Specifications 





B.8 VIDEO 1/O (INT 10H) 


This program interface allows control of the video display. Detailed descriptions 


are provided with each function. 


Functions: AH = 00H 
AH = 01H 
AH = 02H 
AH = 03H 
AH = 04H 
AH = 05H 
AH = 06H 
AH = 07H 
AH = 08H 
AH = 09H 
AH = OAH 
AH = OBH 
AH = OCH 
AH = ODH 
AH = OEH 
AH = OFH 
AH = 13H 
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Set display mode 

Set cursor size 

Set cursor position 

Read cursor position 

Read light pen position 

Select active display page (valid only for 
text modes) 

Scroll window up 

Scroll window down 

Read attribute/character at current 
cursor position 

Write attribute/character at current 
cursor position 

Write character only at current 
cursor position 

Set color palette 

Write dot 

Read dot 

Write character as teletype to 
active page 

Get current video mode 

Write string 
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B.8.1 Set Display Mode 


This function sets the display mode for the active controller. A monochrome 
display controller only uses modes 0 and 7. 


Input: AH = OOH 
AL Mode value 


Text Mode: 
AL = 00H 40x 25 B&W 
AL = 01H 40x 25 color 
AL = 02H 80x 25 B&W 
AL = 03H 80 x 25 color 
AL = 07H 80x 25 B&W Card 
Graphics Mode: 
AL = 04H 320 x 200 color 
AL = 05H 320 x 200 B&W 
AL = 06H 640 x 200 B&W 
AL = 11H 640 x 480 color 
Enhanced Graphics Mode: 


AL = ODH 320 x 200 16 colors 
AL = OEH 640 x 200 16 colors 
AL = OFH 640 x 350 B&W 

AL = 10H 640 x 350 16/64 colors 


Output: None 
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B.8.2 Set Cursor Size 


This function programs the CRTC cursor start/end register to set the desired 
cursor size. 


Input: AH = 01H Set cursor type 
CH (bits 4:0) — Start line for cursor 


(bit 5) Control cursor display 
0 = Normal 
1 = No cursor 

(bit 6) Set to 0 


CL (bits 4:0) — End line for cursor 


Output: None 


B.8.3 Set Cursor Position 


This function programs the CRTC cursor position register to display the cursor at 
the desired location. When the specified page number differs from the active 
display page, no visible reaction occurs. 


Input: AH = 02H 
DH,DL Row, column (0,0 upper left corner) 
BH Page number (must be 0 for graphics modes) 


Output: None 
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B.8.4 Read Cursor Position 


This function returns the current cursor position of the specified page. 


Input: AH = 03H 
BH Page number (must be 0 for graphics modes) 


Output: DH,DL Row, column of current cursor position 
CH,CL Cursor size parameters 


B.8.5 Read Light Pen Position 


This function returns the current light pen position. 


Input: AH = 04H 


Output: AH = 00H Light pen switch not down/not triggered 
AH = 01H Valid light pen value in registers 
DH,DL Row,column of light pen character position 
CH Raster line (0:199) 
BX Pixel column (0:319, 0:639) 


B.8.6 Select Active Display Page 
(Valid Only for Text Modes) 


This function selects the active display page. 


Input: AH = 05H 
AL New page value (0:7 for modes 0 & 1, 0:3 for 
modes 2 & 3) 


Output: None 
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B.8.7 Scroll Window Up 


This function scrolls up the given area in the active page. 


Input: 


AH = O6H 

AL Number of lines blanked at bottom of window 
0 = Blank entire window 

CH,CL Row, column of upper left corner of window 

DH,DL Row, column of lower right corner of window 

BH Attribute used on blank line 


Output: None 


B.8.8 Scroll Window Down 


This function scrolls down the given area in the active page. 


Input: 


AH = 07H 

AL Number of input lines blanked at top of window 
0 = Blank entire window 

CH,CL Row, column of upper left corner of window 

DH,DL Row, column of lower right corner of window 

BH Attribute used on blank line 


Output: None 
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B.8.9 Read Attribute/Character 
Current Cursor Position 


This function gets the attribute and character displayed at the cursor position. 


Input: AH = 08H 
BH Display page (used for text modes only) 


Output: AL Character read 
AH Attribute of character read (text modes only) 


B.8.10 Write Attribute/Character 
at Current Cursor Position 


This function writes the specified attribute and character to the display at the 
current cursor position. Cursor position does not change. 


Input: AH = 09H 


AL Character to write 

BH Display page (used for text modes only) 

BL Attribute of character (text) or color of 
character (graphics) 

CX Number of times to write the character and 
attribute 


In graphics mode the write does not continue 
to the next line 


Output: None 
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B.8.11 | Write Character Only at 
Current Cursor Position 


This function writes the character on the display at the current cursor position. 
Cursor position is unchanged. 


Input: AH = OAH 


AL Character written 
BH Display page (used for text modes only) 
CX Number of times to write the character (in 


graphics mode the write does not continue to 
the next line) 


Output: None 


B.8.12 Set Color Palette 


This function programs the CRTC border control register to set the desired color. 


Input: AH = OBH 
BH Color ID set (0-1) 
BL Color value used with color ID 
BH = 00H Set background color for 320x200 
graphics modes 
Set border color for alphanumeric modes 
set foreground color for 640x200 graphics 


BL = 0-31 

BH = 01H Select palette for 320x200 graphics 
BL=0 Green (1)/red (2)/brown (3) 

BL = 1 Cyan (1)/magenta (2)/white (3) 


Output: None 
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B.8.13 Write Dot 


This function writes a dot at the specified location. 


Input: AH = OCH 
AL Color value 
The color value is exclusive ORed with the 
current color at that location if bit 7 = 1 
CX Column number 
DX Row number 


Output: None 


B.8.14 Read Dot 


This function reads the dot at the specified location. 


Input: AH = ODH 
CX Column number 
DX Row number 


Output: AL Color data 
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B.8.15 | Write Character as Teletype to Active Page 
This function writes a character at the cursor position of the active page and 


moves the cursor to the next position. The attribute remains the same in text 
mode. The cursor moves to the next line and scrolls the screen, if applicable. 


Input: AH = OEH 
AL Character to write 
BL Foreground color in graphics mode 


Output: None 


B.8.16 Get Current Video Mode 


This function returns the current video mode. 


Input: AH = OFH 
Output: AH Number of columns on screen 


AL Mode currently set 
BH Current active display page 
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B.8.17 Write String 


This function displays a string of characters on the display. 


Input: AH = 13H 


ES:BP Pointer to string to write 

CX Length of character string to write 

DH,DL Row, column string write 

BH Page number 

AL = 00H BL = Attribute, string {char, ..., char} 
Cursor does not move 

AL = 01H BL = Attribute, string {char, ..., char} 


Cursor moves 

AL = 02H String {char, attr, ..., char, attr} 
Cursor does not move 

AL = 03H String {char, attr, ..., char, attr} 
Cursor moves 


Output: None 


B-14 Intel386™ MicroComputer Model 300SX Board 


System BIOS Specifications 


B.9 EQUIPMENT DETERMINATION (INT 11H) 


This program interface describes the hardware installed on the system. 


Input: None 


Output: AX 
Bits 15:14 
Bit 13 
Bit 12 
Bits 11:9 
Bit 8 
Bits 7:6 


Bits 5:4 


Bit 3 


Bit 2 


Bit 1 


Bit 0 


Number of printers attached 
Internal modem 

Not used 

Number of RS-232 ports attached 
Not used 

Number of floppy disk drives (00 = 1; 01 = 2 
only if bit O = 1) 

Initial video mode 

00 = Not used 

01 = 40x25 color 

10 = 80x 25 color 

11 = 80x25 monochrome 

Not used 

Pointing device 

1=pointing device installed 
2=pointing device not installed 
Numeric coprocessor 

1 = Numeric coprocessor installed 
0 = Numeric coprocessor not installed 
Floppy disk drive 

1 = Floppy disk drive installed 

0 = Floppy disk drive not installed 
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B.10 MEMORY SIZE DETERMINATION (INT 12H) 


This routine returns the memory size below address 10000H. 


Input: None 


Output: AX Number of contiguous 1K blocks of memory 


B.11 FLOPPY DISK DRIVE I/O (INT 13H, PART 1) 


This interface provides access to the floppy disk drives supported by the system. 


Functions: AH = 00H Reset disk drive 

AH = 01H Read status 

AH = 02H Disk read 

AH = 03H Disk write 

AH = 04H Disk verify 

AH = 05H Format disk track 

AH = 08H Disk drive parameters 

AH = 15H Read direct access storage device 
(DASD) type 

AH = 16H Disk change line status 

AH = 17H Set DASD type for format 

AH = 18H Set media type for format 


Input: AH Function number 
AL Number of sectors 
CH Track number 
CL Sector number 
DH Head number 
DL Drive number 
ES:BX Transfer address 
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Output: Carry flag = 1 
Carry flag = 0 


If operation error 
If operation correct 


AH Status of operation 


No error 

Invalid function request 
Address mark not found 
Write protect error 
Requested sector not found 
Media changed 

DMA overrun 

Attempt to DMA across 64K boundary 
Media type not found 

CRC error on disk read 
General controller failure 
Seek operation failed 
Timeout 


Drive number (0-based) 


Bit 7=0 floppy disk 


AH = OOH 
AH = 01H 
AH = 02H 
AH = 03H 
AH = 04H 
AH = 06H 
AH = 08H 
AH = 09H 
AH = OCH 
AH = 10H 
AH = 20H 
AH = 40H 
AH = 80H 
B.11.1 Reset Disk Drive 
Input: AH = 00H 
Output: DL 
B.11.2 Read Status 


Input: AH = 01H 


Output: DL 


Drive number (0-based) 


Bit 7=0 floppy disk (value checked) 
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B.11.3 Disk Read 


Input: AH = 02H 


AL Number of sectors 
CH Track number 
CL Sector number 


DH Head number 
DL Drive number 
ES:BX Address of buffer 


Output: AH Status of operation 
AL Number of sectors transferred 


CY =1 Error 
CY = 0 No error 


B.11.4 Disk Write 


Input: AH = 03H 


AL Number of sectors 
CH Track number 

CL Sector number 
DH Head number 

DL Drive number 


ES:BX Address of buffer 


Output: AH Status of operation 
AL Number of sectors transferred 
CY = 1 Error 
CY = 0 No error 
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B.11.5 Disk Verify 


Input: AH = 04H 


AL Number of sectors 
CH Track number 
CL Sector number 
DH Head number 
DL Drive number 
Output: AH Status of operation 
AL Number of sectors verified 
CY = 1 Error 


CY = 0 Noerror 


B.11.6 Format Disk Track 


Input: AH = 05H 


Output: AH = 


Number of sectors 
Track number 

Head number 

Drive number 
Address of buffer containing a series of 4 byte 
fields for each sector: 
Byte 1 = Track 

Byte 2 = Head 

Byte 3 = Sector 

Byte 4 = Bytes/sector 
0 = 128 bytes/sector 
1 = 256 bytes/sector 
2 = 512 bytes/sector 
3 = 1024 bytes/sector 


Status of operation 


CY = 1 Error 
CY = 0 Noerror 
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B.11.7 Disk Drive Parameters 
Input: AH = 08H 
DL 
Output: ES:DI 
CH 
CL (bits 7:6) 
(bits 5:0) 
DH 
DL 
BH 
BL (bits 7:4) 
(bits 3:0) 
AX 
B.11.8 Read DASD Type 
Input: AH = 15H 
DL 
Output: AH = 00H 
AH = 01H 
AH = 02H 
AH = 03H 
CY = 
CY =0 
B-20 


Drive number 


Pointer to drive parameter table 

Maximum number of tracks (low order 8 bits) 
Maximum number of tracks (high order 2 bits) 
Maximum sectors per track 

Maximum head number 

Number of floppy disk drives installed 

0 

0 

Valid drive type value stored in CMOS RAM 
01 - 360K drive 

02 - 1.2M drive 

03 - 720K drive 

04 - 1.4M drive 

0 


Drive number 

0-3=floppy 

Drive not present 

Disk, no change line available 
Disk, change line available 
Fixed disk drive 

Error 

No error 
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B.11.9 Disk Change Line Status 


Input: AH = 16H 


DL Drive number 

Output: AH = 01H Invalid parameter 
AH = 80H Drive not ready 
CY =1H AH=non 0 


AH=0 


B.11.10 Set DASD Type For Format 


Input: AH = 17H 


AL = 00H Not used 
AL = 01H 360K floppy disk in 360K drive 
AL = 02H 360K floppy disk in 1.2M drive 
AL = 03H 1.2M floppy disk in 1.2M drive 
AL = 04H 720K floppy disk in 720K drive 
AL = 05H 720K floppy disk in 1.4M drive 
DL Drive number 0-3 

Output: AH Status of operation 
CY =1 Error 
CY =0 No error 


Intel886™ MicroComputer Model 300SX Board B-21 


System BIOS Specifications 


B.11.11 Set Media Type For Format 


Input: AH = 18H 
CH Maximum number of tracks (low order 8 bits) 
CL (bits 7:6) Maximum number of tracks (high order 2 bits) 
(bits 5:0) | Maximum sectors per track 
DL Drive number 


Output: ES:DI Pointer to drive parameter table for this media 
type unchanged if AH is non-zero 
CY =0 
AH = 00H Successful 
Track and sector combination supported 


CY =1 
AH = 01H Function not available 
AH = OCH Track and sector combination not supported 


B-22, Intel386™ MicroComputer Model 300SX Board 


System BIOS Specifications 


B.12 FIXED DISK I/O (INT 13H, PART 2) 


This interface provides access to fixed disk drives through the fixed disk 


controller. 

Functions: AH = 00H 
AH = 01H 
AH = 02H 
AH = 03H 
AH = 04H 
AH = 05H 
AH = 08H 
AH = 09H 
AH = OAH 
AH = 0OBH 
AH = OCH 
AH = ODH 
AH = 10H 
AH = 11H 
AH = 14H 
AH = 15H 

Input: AH 
AL 
CH 
CL 


Disk reset 

Read status 

Read disk 

Write disk 

Verify disk sectors 
Format disk track 
Disk drive parameters 
Initialize disk parameters 
Disk read long 

Disk write long 

Disk seek 

Disk alternate reset 
Disk ready test 

Disk recalibrate 

Disk diagnostics 
Read DASD type 


Function number 

Number of sectors 

Cylinder number (0:1023) 

Sector number (1:17) 

High 2 bits of cylinder number are 
placed in the high 2 bits of the 

CL register 


DH Head number (0:15 are allowed) 
DL Drive number (80H:81H) 
ES:BX Transfer address 


Output: See individual functions 
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B.12.1 Disk Reset 


Input: AH = 00H 
DL Drive number 


Output: AH Status 
CY = 1 Error 
CY = 0 No error 


B.12.2 Read Status 


Input: AH = 01H 
DL Drive number bit7=1 


Output: AH Status of the system 
CY = 1 Error 
CY = 0 No error 


B.12.3 Read Disk 


Input: AH = 02H 
AL Number of sectors 
CH Cylinder number (low order 8 bits) 
CL (bits 7:6) Cylinder number (high order 2 bits) 
(bits 5:0) | Sector number 
Drive number bit7=1 


DH Head number 

ES:BX Address of buffer 
Output: AH Status of operation 

CY = 1 Error 

CY=0 No error 
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B.12.4 Write Disk 
Input: AH = 03H 
AL 
CH 
CL (bits 7:6) 
(bits 5:0) 
DH 
DL 
ES:BX 
Output: AH 
CY = 1 
CY =0 
B.12.5 = Verify Disk Sectors 
Input: AH = 04H 
AL 
CH 
CL (bits 7:6) 
(bits 5:0) 
DH 
Output: CY = 1 
CY=0 
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Number of sectors 

Cylinder number (low order 8 bits) 
Cylinder number (high order 2 bits) 
Sector number 

Head number 

Drive number 

Address of buffer 


Status of operation 
Error 
No error 


Number of sectors 

Cylinder number (low order 8 bits) 
Cylinder number (high order 2 bits) 
Sector number 

Drive number 

Head number 


Error 
No error 
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B.12.6 


B.12.7 
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Format Disk Track 


Input: AH = 05H 


AL Number of sectors 
CH Cylinder number (low order 8 bits) 
CL (bits 7:6) Cylinder number (high order 2 bits) 
(bits 5:0) | Sector number 
Drive number 
DH Head number 
ES:BX Address of buffer for reads and writes 
This points to a 512 byte buffer 
The first 2 x (number of sectors/track) bytes 
contain F, N for each sector 
where: F = OOH for a good sector, 
80H for a bad sector, and 
N = logical sector number 
Output: AH Status of operation 
CY = 1 Error 
CY =0 No error 
Disk Drive Parameters 
Input: AH = 08H 
DL Drive number 
Output: AX = 0 
BH = 0 
DL Number of disk drives installed 
DH Maximum usable head number 
CH Cylinder number (low order 8 bits) 
CL (bits 7:6) Cylinder number (high order 2 bits) 
(bits 5:0) Sector number 
CY =1 Error 
CY =0 No error 
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B.12.8 Initialize Disk Parameters 


Input: AH = 09H 
DL Drive number 


Output: AH Status 
CY = 1 Error 
CY = 0 No error 


B.12.9 Disk Read Long 


Input: AH = OAH 

AL Number of sectors 

CH Cylinder number (low order 8 bits) 

CL (bits 7:6) Cylinder number (high order 2 bits) 

(bits 5:0) = Sector number 

Head number 

DL Drive number 

ES:BX Buffer address (must accommodate four bytes 
of ECC per sector) 


Output: AH Status of operation 
CY =1 Error 
CY=0 No error 
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B.12.10 


B.12.11 
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Disk Write Long 
Input: AH = OBH 
AL 
CH 
CL (bits 7:6) 
(bits 5:0) 
DH 
DL 
ES:BX 
Output: AH 
CY = 1 
CY =0 
Disk Seek 
Input: AH = OCH 
CH 
CL (bits 7:6) 
(bits 5:0) 
DH 
DL 
Output: AH 
CY =1 
CY =0 


Number of sectors 

Cylinder number (low order 8 bits) 

Cylinder number (high order 2 bits) 

Sector number 

Head number 

Drive number 

Buffer address 

Each sector of data is followed by the 4-byte 
ECC 


Status of operation 
Error 
No error 


Cylinder number (low order 8 bits) 
Cylinder number (high order 2 bits) 
Sector number 

Head number 

Drive number 


Status of operation 


Error 
No error 
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B.12.12 Disk Alternate Reset 
(Same as Function 00H) 


Input: AH = ODH 
DL Drive number 


Output: AH Status 


CY = 1 Error 
CY = 0 No error 


B.12.13 Disk Ready Test 


Input: AH = 10H 
DL Drive number 


Output: AH Status (if fixed disk drive present) 


CY = 1 Error 
CY = 0 Noerror 


B.12.14 Disk Recalibrate 


Input: AH = 11H 
DL Drive number 


Output: AH Status (if fixed disk drive present) 


CY = 1 Error 
CY = 0 No error 
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B.12.15 Disk Diagnostics 


Input: AH = 14H 
DL Drive number 


Output: AH Status 


CY = 1 Error 
CY = 0 Noerror 


B.12.16 Read DASD Type 


Input: AH = 15H 
DL Drive number 


Output: AH = 00H Drive not present 
AH = 01H Disk, no change line available 


AH = 02H Disk, change line available 

AH = 03H Fixed disk drive 

CX:DX Contains total number of sectors 
CY =1 Invalid drive number 

CY=0 No error 
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B.13 RS232 I/O (INT 14H) 


This program interface provides access to the asynchronous communication I/O 
port. The communication port number is not checked. 


Functions: AH = 00H Initialize the communication port 
AH = 01H Send a character 
AH = 02H Receive a character 
AH = 03H Return the communication port status 
Input: AH Function number 
DX Communication port number (0:3) 


Output: See individual functions 
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B.13.1 Initialize the Communication Port 


Input: AH = 00H 
DX Communication port number (0:3) 
AL Parameters for initialization 
Bits 7:5 Baud rate 
000 = 110 bps 
001 = 150 bps 
010 = 300 bps 
011 = 600 bps 
100 = 1200 bps 
101 = 2400 bps 
110 = 4800 bps 
111 = 9600 bps 
Bits 4:3 Parity 
00 = No parity 
01 = Odd parity 
10 = No parity 
11 = Even parity 
Bit2 Stop bit 
0 = 1 stop bit 
1 = 2stop bits 
Bits 1:0 Word length 
10 =7 bits 
11 = 8 bits 
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Output: AH 
Bit 7 
Bit 6 
Bit 5 
Bit 4 
Bit 3 
Bit 2 
Bit 1 
Bit 0 
AL 
Bit 7 
Bit 6 
Bit 5 
Bit 4 
Bit 3 
Bit 2 
Bit 1 
Bit 0 


Line control status: 

Time out 

Transmitter shift register empty 
Transmitter holding register empty 
Break detected 

Framing error 

Parity error 

Overrun error 

Data ready 

Modem status: 

Received line signal detect 
Ring indicator 

Data set ready 

Clear to send 

Delta receive line signal detect 
Trailing edge ring detector 
Delta data set ready 

Delta clear to send 
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B.13.2 Send a Character 


Input: AH = 01H 
AL Character 


DX Communication port number (0:3) 
Output: AL Character 

AH Status of operation 

Bit7 =0 See below 

Bit7 =1 Time out error 


If bit 7 of AH is 0, then: 


Bit6 —_ Transmitter shift register empty 
Bit5 — Transmitter holding register empty 
Bit4 Break detected 

Bit3 Framing error 

Bit2 Parity error 

Bit1 | Overrun error 

BitO Dataready 
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B.13.3 Receive a Character 


Input: AH = 02H 


DX 


Communication port number (0:3) 


Output: AH = 00H No error 


AL Character received 

AH Status of operation 

Bit 7 =0 Character was received 
Bit 7 = 1 Error encountered 


If bit 7 of AH is 0, then: 


Bit 6 
Bit 5 
Bit 4 
Bit 3 
Bit 2 
Bit 1 
Bit 0 


Transmitter shift register empty 
Transmitter holding register empty 
Break detected 

Framing error 

Parity error 

Overrun error 

Data ready 
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B.13.4 Return the Communication Port Status 


Input: AH = 03H 
DX Communication port number (0:3) 


Output: AH Communication line status: 
Bit7 Time out 
Bit6 Transmitter shift register empty 
Bit5 Transmitter holding register empty 
Bit4 Break detected 
Bit3 Framing error 
Bit2 Parity error 
Bit1 | Overrun error 
BitO Data ready 
AL Modem status: 
Bit7 Received line signal detect 
Bit6 —_ Ring indicator 
Bit5 Dataset ready 
Bit4 Clear to send 
Bit3 Delta receive line signal detect 
Bit2 Trailing edge ring detector 
Bit1 Delta data set ready 
BitO Delta clear to send 
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B.14 SYSTEM SERVICE ROUTINES (INT 15H) 


This program interface allows access to the 386 extended functions. 


Functions: AH = 44H 
AH = 4FH 
AH = 80H 
AH = 81H 
AH = 82H 
AH = 83H 
AH = 84H 
AH = 85H 
AH = 86H 
AH = 87H 
AH = 88H 
AH = 89H 
AH = 90H 
AH = 91H 
AH = COH 
AH = C1H 

Input: AH 


Output: See individual functions 


B.14.1 Get Video Configuration Byte 


Input: AH = 44H 
AL = 8EH 


Onboard video setup 

Keyboard intercept (null) 

Device open (null) 

Device close (null) 

Program termination (null) 

Event wait (null) 

Joystick support 

System request key pressed (null) 
Wait 

Move block 

Extended memory size determination 
Switch coprocessor to virtual mode 
Device busy (null) 

Interrupt complete (null) 

Return system configuration parameters 
Get mouse data area 


Function number 


Output: DH (bit 0) State of Setup "Analog Monochrome Monitor" 
DL (bits 3:0) State of Setup "Monitor Type" 
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B.14.2 Get Video Options Byte 


Input: AH = 44H 


AL = 8FH 
Output: AH = 0 
DH (bit 7) State of Setup "Video Registers" 
(bit 6) State of CMOS byte 2CH bit 4 


DL (bits 7:5) State of CMOS byte 2DH bits 7:5 


B.14.3. Keyboard Intercept 


The H/W keyboard interrupt INT O9H routine calls the keyboard intercept 
asynchronously. This allows keystroke changes. Normally the system returns 
with the scan code unchanged, but the operating system can redirect interrupt 
15H to its own routine and 


e@ Replaces (AL) with a different scan code and return with the carry flag set, 
effectively changing the keystroke. 


@ Processes the keystroke and return with the carry flag cleared, causing the 
interrupt O9H routine to ignore the keystroke. 


The RET 2 instruction must be used when returning from scan code handling. 


This clears the stack and prevents the flag just set from being overwritten with its 
previous state. 


Input: AH = 4FH 
Output: AL Scan code 


CY = 1 Handle code 
CY = 0 Ignore keystroke 
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B.14.4 Device Open 
This function reserved for the operating system. 
Input: AH = 80H 
BX Device ID 
CX Process ID 


Output: AH = 0 
CY =0 


B.14.5 Device Close 
This function reserved for the operating system. 
Input: AH = 81H 
BX Device ID 
CX Process ID 


Output: AH = 0 
CY =0 


B.14.6 Program Termination 
This function reserved for the operating system. 
Input: AH = 82H 
BX Device ID 


Output: AH = 0 
CY=0 
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B.14.7 Event Wait 


This function sets a timer which counts off CX:DX microseconds. When the timer 
expires, the high bit of the byte pointed to by ES:BX sets. Make sure the bit 
clears initially, and monitor the bit after invoking this function. The real-time clock 
periodic interrupt counts the interval (1/1024th of a second). The event wait 
handler takes this into account, however, the shortest interval available is 1 ms. 


Input: AH = 83H 
AL = 0 Set interval 
AL = 1 Cancel 
ES:BX Pointer to a byte 
CX:DX Number of microseconds to wait 


Output: CY = 0 Not busy (AL not equal to 0) 


CY = 1 Busy (AL = 0) 
AH = 0 
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B.14.8 Joystick Support 


This routine supports an interface between a joystick interface and the system. 


Input: AH = 84H 
DX = 0 Read current switch settings 
DX = 1 Read resistive inputs 


Output: CY = 1 Invalid call 
lf DX = 0 
AL = Switch setting (bits 7:4) 


If DX = 4 


AX = a(x) value 
BX = a(y) value 
CX = b(x) value 
DX = b(y) value 


B.14.9 System Request Key Pressed 


Pressing the system request key (SysRq) key loads the BIOS keyboard hardware 
interrupt routine, loads AX with 8500H, and invokes INT 15H. This vector can be 
revectored. Releasing the key invokes INT 15H, this time with 8501H in AX. 


Input: AH = 85H 
AL = 00 key pressed 
AL = 01 key released 


Output: AH = 0 
CY =0 
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B.14.10 Wait 


This function waits for the specified number of microseconds before returning. 
The real-time clock periodic interrupt counts the interval (1/1024th of a second). 
The event wait handler takes this into account, however, the shortest interval 


available is 1 ms. 


Input: AH = 86H 


CX,DX Number of microseconds to elapse before 
return to caller 


Output: CY = 0 Function successful 
CY = 1 Wait function already in progress 


B.14.11 Move Block 


This function transfers up to 32,768 words to or from memory. 


Input: AH = 87H 
CX 


ES:SI 


Output: AH = 00H 


AH = 01H 
AH = 02H 
AH = 03H 
CY=0 
CY = 1 
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Number of words to move, maximum count = 
8000H (32K) words 

Global descriptor table (GDT) pointer. 

User must set up the GDT. 


Successful 

RAM parity (parity error cleared on return) 
Exception interrupt occurred 

Gate address line 20 failed 

Successful 

Error 
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B.14.12 Extended Memory Size Determination 


This routine returns the number of consecutive 1K blocks above 1M. CMOS 
RAM locations 30H and 31H, set when the system was started, obtains this 
value. 


Input: AH = 88H 


Output: AX Number of consecutive 1K blocks starting at 1M 


B.14.13 Switch Processor to Protected Mode 


This routine sets the coprocessor to protected mode. 


Input: AH = 89H 
ES:S!_ Pointer to GDT. User must set 
up the GDT 
BH Offset into interrupt descriptor table (IDT) 
where first eight 8259 interrupts are to occur 
BL Offset into IDT where second eight 8259 
interrupts occur 


Output: AH = 0 If successful 


Segment registers set for protected mode 
operation, AX and BP destroyed 
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B.14.14 Device Busy 


This function reserved for the operating system. 


Input: AH = 90H 
AL Type code 


Output: CY = O No error 


CY = 1 Timeout 
Type Description Timeout 
00 Fixed disk yes 
01 Disk yes 
02 Keyboard no 
80 Network no 


FC Fixed diskreset yes 
FD Drive motor start yes 
FE Printer yes 


B.14.15 Interrupt Complete 


This function reserved for the operating system. 


Input: AH = 91H 
AL Type code 


Output: None, AX destroyed 
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B.14.16 Return System Configuration Parameters 


This routine gives information about the model of the board, the BIOS revision 
level, and hardware features. 


Input: AH = COH 
Output: CY = 0 


AH =0 
ES:BX Pointer to system descriptor table in ROM 


System Descriptor Table: 


Size Description Value 
Word Descriptor length (bytes) 008H 
Byte Model FCH 
Byte Submodel 81H 
Byte BIOS revision level 00H 
Byte Feature information 70H 
Bit 7 = 1 BIOS uses DMA channel 3 
Bit6 = 0 One interrupt controller 
Bit5 = 1 Real-time clock present 
Bit4 = 1 System hook in keyboard 

interrupt routine 
Bit3 = 0 Reserved 
Bit2 = 1 Extended BIOS data area 

allocated 
Bit1 =0 Reserved 
BitO = 0 Reserved 
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B.14.17. Get Mouse Data Area 


This function reserved for the operating system. 


Input: AH = C1H 
Output: CF = 0 


ES = Segment of mouse data 
Mouse data starts at ES:22 


==> NOTE 
This is not a complete extended BIOS data area. It is only for mouse data. 
B.15 KEYBOARD I/O (INT 16H) 


This program interface provides an interface to access keys placed into the 
keyboard buffer by the keyboard hardware interrupt. 


Functions: AH = OOH Read next character 

AH = 01H Read buffer status 

AH = 02H Return shift status 

AH = 03H Set typematic rate and delay 

AH = 05H Place ASCII character/scan code in 
keyboard buffer 

AH = 10H Extended read interface for the 
enhanced keyboard 

AH = 11H Extended buffer status for the enhanced 
keyboard 

AH = 12H Return the extended shift status for the 


enhanced keyboard 
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B.15.1 


B.15.2 


Read Next Character 
This function returns the scan code and ASCII code of the next character in the 


keyboard buffer, and updates the buffer pointer. If the keyboard buffer is empty, 
the function waits for a key. 


Input: AH = 00H 
Output: AH Scan code 


AL ASCIl character (0 for special keys, function 
keys, etc.) 


Read Buffer Status 
This function returns the keyboard buffer status (indicates whether a keystroke is 


available or not). The buffer pointer is not updated, even though the key returns. 
Use function 00H to update the buffer pointer. 


Input: AH = 01H 


Output: ZF = 1 No keystroke queued 
ZF = 0 Keystroke available in queue, key in AX 
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B.15.3 Return Shift Status 


Pressing a shift key does not transfer code/ASCIl code into the keyboard buffer. 
Instead, a shift status bit sets. This function indicates which key is pressed. 


Right-Shift pressed 
Left-Shift pressed 
Ctrl-Shift pressed 
Alt-Shift pressed 
Scroll Lock state 
Num Lock state 
Caps Lock state 


Input: AH = 02H 
Output: AL Shift status 
BitO = 1 
Bit1 =1 
Bit2 = 1 
Bit3 = 1 
Bit 4 = 1 
Bit5 = 1 
Bit6 = 1 
Bit7 = 1 


Insert state 


All other registers are restored 


B.15.4 Set Typematic Rate and Delay 


Pressing a key (except a shift key) causes the keyboard handler to repeat the key 
until the key is released. This function allows the keyboard typematic rate and 
keyboard delay time to be set. The typematic rate is the rate at which the handler 
repeats the key. Delay time is the time between the first keystroke and the 


repeated keystrokes. 
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Input: AH = 03H 


BL Typematic rate (bits 4:0) 


BL = 00H 
BL = 01H 
BL = 02H 
BL = 03H 
BL = 04H 
BL = 05H 
BL = 06H 
BL = 07H 
BL = 08H 
BL = 09H 
BL = OAH 
BL = OBH 
BL = OCH 
BL = ODH 
BL = OEH 
BL = OFH 


30.0 
26.7 
24.0 
21.8 
20.0 
18.5 
17.1 
16.0 
15.0 
13.3 
12.0 
10.9 
10.0 
9.2 

8.5 

8.0 


BL = 10H 
BL = 11H 
BL = 12H 
BL = 13H 
BL = 14H 
BL = 15H 
BL = 16H 
BL = 17H 
BL = 18H 
BL = 19H 
BL = 1AH 
BL = 1BH 
BL = 1CH 
BL = 1DH 
BL = 1EH 
BL = 1FH 


BH Delay value (bits 1:0) 

250 milliseconds 
500 milliseconds 
750 milliseconds 
1000 milliseconds 


BH = 00H 
BH = 01H 
BH = 02H 
BH = 03H 


Output: None 
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B.15.5 Place ASCII Character/Scan Code in Keyboard Buffer 


This function places an ASCII character/scan code combination into the keyboard 


buffer. 
Input: AH = 05H 
CL ASCIl code 
CH Scan code 
Output: AL = 00H Successful operation 
AL = 01H Keyboard buffer full 


B.15.6 | Extended Read Interface for the Enhanced Keyboard 
This function corresponds to AH = 0, but supports the enhanced keyboard. 


Input: AH = 10H 


Output: AH Scan code 
AL ASCIl code 


B.15.7. Extended Buffer Status for the Enhanced Keyboard 


This function corresponds to AH = 1, but supports the enhanced keyboard. 
Input: AH = 11H 


Output: ZF = 1 No keystroke queued 
ZF = 0 Keystroke is available, key in AX 
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B.15.8 Return the Extended Shift 
Status for the Enhanced Keyboard 


This function corresponds to AH = 2, but supports the enhanced keyboard. 


Input: = AH = 12H 


Output: AL 
BitO = 1 
Bit1 = 1 
Bit2 = 1 
Bit3 = 1 
Bit4 =1 
Bit5 = 1 
Bit6 = 1 
Bit7 = 1 

Output: AH 
BitO = 1 
Bit1 =1 
Bit 2 = 1 
Bit 3 = 1 
Bit 4 = 1 
Bit5 = 1 
Bit6 = 1 
Bit 7 = 1 


Right-Shift key pressed 
Left-Shift key pressed 
Control key pressed 
Alt key pressed 

Scroll Lock state 

Num Lock state 

Caps key state 

Insert state 


Left-Ctrl-Shift 
Left-Alt-Shift 
Right-Ctrl-Shift 
Right-Alt-Shift 
Scroll-Lock-Shift 
Num-Lock-Shift 
Caps-Lock-Shift 
SysRq-Shift 
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B.16 PRINTER I/O (INT 17H) 


This program interface allows access to the printer 


Functions: AH = 00H Print character 
AH = 01H Initialize printer port 
AH = 02H Read printer status 
Input: AH Function number 
DX Device number (0:2) 


Output: See individual functions 


B.16.1 Print Character 


This function writes the character in AL to the specified printer. 


Input: AH = 00H 


AL Character 

DX Device number (0:2) 
Output: AH = OFH Invalid port 

AH Printer status 

BitO = 1 Timeout 

Bits 1:2 Reserved 

Bit3 = 1 /O error 

Bit 4 = 1 Printer selected 

Bit5 = 1 Out of paper 

Bit 6 = 1 Acknowledge 

Bit7 =1 Not busy 
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B.16.2 Initialize Printer Port 
Input: = AH = 01H 
DX 
Output: AH 
BitO = 1 
Bits 1:2 
Bit 3 = 1 
Bit 4 = 1 
Bit5 = 1 
Bit 6 = 1 
Bit 7 = 1 
B.16.3 Read Printer Status 
Input: AH = 02H 
DX 
Output: AH 
BitO = 1 
Bits 1:2 
Bit3 = 1 
Bit 4 = 1 
Bit5 = 1 
Bit6 = 1 
Bit 7 = 1 


Device number (0:2) 


Printer status 
Timeout 
Reserved 

/O error 

Printer selected 
Out of paper 
Acknowledge 
Not busy 


Device number (0:2) 


Printer status 
Timeout 
Reserved 

/O error 

Printer selected 
Out of paper 
Acknowledge 
Not busy 
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B.17 SYSTEM BOOT (INT 19H) 
This routine reads the boot-sector from the disk drive into main memory and 
executes it. Memory does not clear unless invoked by the BIOS self-test and 


initialization. If a disk time-out is encountered, the routine attempts to boot from 
the fixed disk drive. If this fails, INT 18H invokes. 


Input: None 


Output: None 


B.18 CLOCK SERVICES (INT 1AH) 


This routine allows the clock to be set or read. 


Functions: AH = 00H Read the system timer count 
AH = 01H Set the system timer count 
AH = 02H Read the real-time clock time 
AH = 03H Set the real-time clock time 
AH = 04H Read the real-time clock date 
AH = 05H Set the real-time clock date 
AH = 06H Set the real-time clock alarm 
AH = 07H Reset the real-time clock alarm 

Input: Function number 

Output: See individual functions 
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B.18.1 Read the System Timer Count 


This function reads the system timer from the BIOS data area. Each system timer 
interrupt (INT 08H), approximately 18.2 times per second, increments this value. 


Input: AH = OOH 


Output: CX High count word 
DX Low count word 
AL = 0 Timer has not passed midnight since last read 


AL > 0 Timer has passed midnight since last read 
AH = 0 


B.18.2 Set the System Timer Count 


This function sets the system timer in the BIOS data area. 


Input: AH = 01H 
CX High count word 
DX Low count word 


Output: AH = 0 
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B.18.3 Read the Real-Time Clock Time 


This function reads hours, minutes, and seconds from the real-time clock. 


Input: AH = 02H 


Output: CH Hours in BCD 
CL Minutes in BCD 
DH Seconds in BCD 
DL = 1 Daylight savings time 
DL = 0 Standard time 
CY = 0 Successful 
CY = 1 Clock is busy 


B.18.4 Set the Real-Time Clock Time 


This function sets hours, minutes, and seconds in the real-time clock. 


Input: AH = 03H 
CH Hours in BCD 
CL Minutes in BCD 
DH Seconds in BCD 
DL = 1 Daylight savings time 
DL = 0 Standard time 


Output: AH = 00H 


CY = 0 Successful 
CY = 1 Clock is busy 
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B.18.5 Read the Real-Time Clock Date 


This function reads century, year, month, and day from the real-time clock. 


Input: AH = 04H 


Output: CH Century in BCD (19 or 20) 
CL Year in BCD 
DH Month in BCD 
DL Day in BCD 
AH = 00H 
CY = 0 Successful 
CY = 1 Clock busy 


B.18.6 Set the Real-Time Clock Date 


This function sets century, year, month, and day into the real-time clock. 


Input: AH = 05H 
CH Century in BCD (19 or 20) 
CL Year in BCD 
DH Month in BCD 
DL Day in BCD 


Output: AH = 00H 


CY = 0 Successful 
CY = 1 Clock busy 
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B.18.7 Set the Real-Time Clock Alarm 


This function sets the alarm (hours, minutes, and seconds) to the real-time clock. 
When the time is up, INT 4AH invokes. 


Input: AH = 06H 
CH Hours in BCD 
CL Minutes in BCD 
DH Seconds in BCD 
Output: AH = 00H 
CY = 0 Successful 
CY = 1 Clock busy 


B.18.8 Reset the Real-Time Clock Alarm 


This function resets the alarm and turns off the alarm enable. 


Input: AH = 07H 
Output: AH = 00H 


CY = 0 Successful 
CY = 1 Clock busy 


B.19 REAL-TIME CLOCK (INT 70H) 
The following three conditions in the real-time clock may cause this interrupt: 
e The current time matches the time set in the alarm. 
@ The periodic interval counter expires. 


e@ The real-time clock completes an internal update cycle. 
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B.20 


B.21 


B.22 


Each separately enabled condition must be enabled for an interrupt to occur. In 
a standard system, only the periodic interrupt is enabled. BIOS uses this periodic 
interrupt to time certain events in the system. If an alarm interrupt occurs, BIOS 
invokes INT 4AH and gives the program a chance to handle the alarm condition. 
The update cycle complete interrupt is not used. 


AUXILIARY DEVICE (MOUSE) INTERRUPT (INT 74H) 


Interrupt 70H is the interrupt service routine for auxiliary devices. When the 
mouse has data to transmit to the system, it sends the data to the keyboard and 
mouse controller. The data is transmitted to a data package. After the keyboard 
and mouse controller receives the data, it interrupts the system on IRQ12. 

INT 74H collects each byte of the data package and stores it in the BIOS 
extended data area. INT 74H also sets appropriate flags if an acknowledge, 
resend, or self-test completion code is received. When all information in the data 
package has been collected and stored, INT 74H pushes the data onto the stack 
and calls the auxiliary device driver. 


COPROCESSOR INTERRUPT (INT 75H) 


This interrupt is caused by the 387SX™ numeric coprocessor error, which occurs 
with interrupts enabled at the coprocessor. To retain compatibility with 
8088-based systems, the IRQ13 handler issues a software INT 02H command. 
INT 02H causes a software generated NMI. 


If an application preempts the NMI vector to handle coprocessor errors (as it 
must to retain compatibility with 8088-based systems), it must be sensitive to 
NMIs generated by hardware, and pass them on to the system NMI. 


FIXED DISK H/W INTERRUPT (INT 76H) 


This interrupt occurs when the fixed disk drive requires attention. During 
multi-sector transfers, the controller interrupts for each transfer. A completed 
operation also causes an interrupt. The BIOS handler moves OFFH to 40:8EH 
indicating the interrupt occurred. 
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Cl INTRODUCTION 
Jumper pins allow specific system operating parameters to be set into the 
system. Various options require changing jumper blocks to reflect the correct 
system configuration. 


Figure C-1 diagrams the system board jumper pin locations. Jumper pin blocks 
are arranged into the following functional groups: 


@ Monitor type monochrome/color 
e@ Password enable/clear 
e@ ROM size (512K/256k) 
e@ Video enable/disable 
=> NOTE 


The POST must be executed after any changes are made to the jumper 
settings. 
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ROM Size 


E1 E2 E3 























E10 
E11 

Color 
E12 Monitor 
E13 
E14 

Password 
E15 Enable 


Figure C-1. System Board Jumper Locations 





Video 
Enable/Disable 


E7 E8 E9 





A10045 
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C.2 


MONITOR TYPE 
The monitor type jumper allows you to indicate the type of monitor connected to 
the 300SX board’s TTL video output connector. If the monitor is one of the 
following, the jumper must be set to MD (monochrome display) as indicated in 
Table C-1: 
Monochrome Displays: 

e@ Princeton Graphics MAX-12 

@ Amdek 310A 

e IBM 5151 
If you are connecting any other monitor, the jumper should be set to color. If the 


TTL connector is not used, the jumper should be set to color. 


Table C-1. Color/Monochrome Monitor 


Monitor Type Jumper Pin Setting 
Color E10 to E11t 
Monochrome E11 to E12 


+ Default setting. 
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C.3 


C.4 


C-4 


PASSWORD ENABLE/CLEAR 


This jumper enables or clears the password function. If the password is enabled, 
a password may be entered into the board ROM using the SETUP utility. The 
jumper settings are shown in Table C-2. 


Table C-2. Password Enable/Clear 





Enable E13 to E14 
Clear E14 to Fist 


Tt Default setting. 


ROM SIZE 


If the onboard video subsystem is being used, the ROM size jumper must be set 
to 512 to indicate 512K devices. If the onboard video subsystem is disabled, the 
ROM sized jumper should be set to 256K devices, to disable the onboard video 
BIOS. The jumper settings are shown in Table C-3. 


Table C-3. Password Enable/Clear 


512K Devices E1 to Eot 
256K Devices E2 to E3 


Tt Default setting. 
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C.5 VIDEO ENABLE/DISABLE 


If an offboard video controller is installed in one of the ISA bus expansion slots, 
the onboard video controller must be disabled to prevent a conflict between the 
two controllers. The jumper settings are listed in Table C-4. 


Table C-4. Video Enable/Disable 





Onboard Video enabled E7 to Eat 
Onboard video disabled E8 to EQ 


tT Default setting. 


==> NOTE 
To completely disable the onboard video circuitry, the ROM size jumper 
should be set to 256K devices when you disable onboard video 


Intel386™ MicroComputer Model 300SX Board C-5 


intel 


Changing CPU Speed 


D.1 INTRODUCTION 
This chapter describes how to change the speed of the CPU on the 300SX 
board. 

D.2 CPU CLOCK SPEED 


The CPU runs at a clock speed of 16 MHz, resulting in system clock cycles of 
625 ns. However, there are some applications (such as those installing some 
copy-protected software), that cannot operate at a clock speed of 16 MHz, and 
instead require slower operation. To meet this requirement, a special mode can 
be initiated which enables the board to effectively operate at a slower speed to 
simulate the performance of a 8 MHz IBM AT. This special mode of operation is 
called deturbo mode. The opposite of deturbo mode (normal system operation) 
is sometimes referred to as turbo mode. Deturbo mode can be enabled in the 
setup program, from the keyboard, or with a software program. Conversely, the 
normal or turbo mode can be enabled in the same manner. 


Deturbo mode does not actually affect the clock rate of the 386SX nor the 387SX. 
Deturbo mode inserts CPU wait states between each instruction, resulting in an 
effective CPU clock speed of 8 MHz. 


If the system is put in deturbo mode, it will remain in deturbo mode even after 
warm reboots ({ctr] + [Ait] + [Delete]) or other software resets. However, a power 
reset will put the CPU back into normal (turbo) 16 MHz operation. 
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D.3 


D.4 


KEYBOARD METHOD 


The following keystroke sequences can be used to set the CPU speed. 


+ [Ar] +B] Hold down the and [ait] keys and press [i] on the 
numeric keypad to place the system in deturbo mode. 


+ [ar] +] Hold down the and [ait] keys and press [2] on the 
numeric keypad to place the system in turbo mode. 


An audible tone occurs when you change the CPU clock speed via the keyboard. 
A low-pitched tone will be emitted when the system is placed into deturbo mode. 
A high-pitched tone will be emitted when the system is returned to normal 
operation. 


SETUP METHOD 


The CPU clock speed can be changed using the Setup program. The CPU clock 
speed chosen determines the speed used by the 300SX system each time it is 
powered up. 


To invoke Setup, press + + [ins]. Press the [ft] or EJ to move the cursor to 


the CPU speed field. Press the [<] or ] to display the turbo or deturbo options. 
Exit Setup by pressing [Es]. 
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SOFTWARE METHOD 


Figure D-1 lists the assembly language code for the SLOW.COM routine. This 
routine is used to place the system in deturbo mode. Figure D-2 lists the 
assembly language code for the FAST.COM routine. This routine is used to 
return the system to full speed operation. Both of these programs run under 
DOS and can be assembled using the Microsoft Macro Assembler. Assuming 
that the FAST.COM routine shown in Figure D-2 is contained in a file called 
FAST.ASM, the following commands can be used to assemble the program and 
make it ready to run (user input is in italic type). The procedure for preparing the 
SLOW.COM program shown in Figure D-1 is analogous. 


C:>masm fast, fast, fast; 


Microsoft (R) Macro Assembler Version 4.00 
Copyright (C) Microsoft Corp 1981, 1983, 1984, 1985. All rights reserved. 


50460 Bytes symbol space free 
0 Warning Errors 
0 Severe Errors 


C:>link fast; 

The IBM Personal Computer Linker 

Version 2.40 (C) Copyright International Business Machines Corp 1981, 1985 (C) 
Copyright Microsoft Corp. 1981, 1985 

Warning: no stack segment 

C:>exe2bin fast.exe fast.com 


C:>del fast.obj 
C:>del fast.exe 
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name slow 


title 


cr equ 
lf equ 
cmnd equ 
code segment 


org 


start: 
mov 
mov 


mov 
out 


mov 


mov 
int 


mov 
int 


deturbo db 


code ends 
end start 


Figure D-1. 


"SLOW.COM -- puts board into deturbo mode 
(simulated 8 MHz)' 


Odh ; ASCII carriage return 
Oah 3; ASCII line feed 
64h ; command register 


public 

100h 3; COM file 

assume cs:code,ds:code 

ax, cS 3; set ds equal to cs 
ds ,ax 


al,Oeah 3 value for deturbo mode 
cmnd,al ; write to command port 


dx,offset deturbo ; tell user that switch occurred 
ah,9 3; use DOS function 9 to print the string 
21h 


ax,4c00h 3; exit back to DOS with 
21h 3 a return code of zero 


cr,1f,'Now running in deturbo mode. 'cr,1f,'$' 


Code Listing for SLOW.COM Routine (Setting Deturbo Mode) 
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cr 
lf 
cmnd 


code 


start: 


turbo 


code 
end 


name 
title 


equ 
equ 
equ 


segment 


org 


mov 
mov 


mov 
out 


mov 


mov 
int 


mov 
int 


db 


ends 
start 


Figure D-2. 


fast 
"FAST.COM -- puts board into turbo mode 


Odh ; ASCII carriage return 
Qah 3; ASCII line feed 

64h ; command register 
public 

100h ; COM file 


assume cs:code,ds:code 


ax, cS 3; set ds equal to cs 

ds ,ax 

al,Qe5h 3; value for turbo mode 
cmnd,al 3; write to command port 


dx,offset turbo ; tell user that switch occurred 


ah,9 ; use DOS function 9 to print the string 
21h 


ax,4c00h 3; exit back to DOS with 
21h 3; a return code of zero 


cr,]f,'Now running in turbo mode.'cr,1f,'$' 


Code Listing for FAST.COM Routine (Setting Turbo Mode) 
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E.1 INTRODUCTION 


This appendix describes the various system screen messages and error beep 
codes. Information is grouped as follows: 


e POST and boot error messages 
e POST and boot informational messages 
e Run-time messages 
e@ System board errors 
e@ Beep codes for fatal errors 
e@ Beep codes for non-fatal errors 
E.2 POST AND BOOT MESSAGES 


The POST displays messages to indicate errors in hardware, software, or 
firmware, or to provide other information. 


If the POST can display a message on the video display screen, it will beep the 
speaker twice as the message appears. However, when an error occurs before 
the video display is initialized, the POST cannot display messages on the screen. 
POST sounds a series of beeps instead. 
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The next three sections provide a general grouping of messages, with each 
group arranged in alphabetical order. Each message is accompanied by a short 
paragraph describing the message and gives a recommended solution to the 
problem. 


Italics indicate variable parts of a message such as memory addresses. These 
variable parts of the message may differ at each occurrence. 


E.2.1 POST and Boot Error Messages 


Message: Coprocessor failed 


Possible Cause: | Coprocessor not correctly sealed in its socket or the 
coprocessor has failed. 


Solution: Reseat the coprocessor chip. Rerun the Setup program. If 
the coprocessor still fails, call your service representative. 


Message: Diskette drive 0 seek failure 
Possible Cause: _ Drive A has either failed or is missing. 


Solution: Make sure drive A is present and the floppy disk is inserted 
properly. If they are, then drive A may have failed. 


Message: Diskette drive 1 seek failure 
Possible Cause: Drive B has either failed or is missing. 


Solution: Make sure drive B is present and the floppy disk is inserted 
properly. If they are, then drive B may have failed. 


Message: Diskette read failure - 
strike Fl to retry boot 


Possible Cause: — The two most likely causes for this condition are: (1) the 
floppy disk is not bootable, and (2) the floppy disk is 
defective. 


Solution: Replace the floppy disk with a bootable floppy disk and try 
again. Clean the drive heads if necessary. 
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Message: Diskette subsystem reset failed 
Possible Cause: The floppy disk adapter cable has failed. 
Solution: Check the floppy disk adapter cable. 


Message: Display adapter failed; using alternate 


Possible Cause: — The video display type jumpers are set incorrectly or the 
primary video adapter failed. 


Solution: Make sure the video display type jumpers are set correctly. 
Check the primary video adapter. 


==> NOTE 
The following basic message precedes any of the possible errors 
numbered 1 through 6. These errors can only occur when the setup 
program is run. 


Message: Errors have been found during the power on self 
test in your system. The errors were: 


1 Clock chip lost power 

2 CMOS checksum invalid 

3 Incorrect configuration data in CMOS 
4 Memory size in CMOS invalid 

5 Disk C: failed initialization 

6 Time or Date in CMOS is invalid 


Hit any key to continue 


Possible Cause: — The configuration information stored in the real-time clock 
CMOS memory chip does not agree with the hardware 
configuration of the system. 


Solution: Make sure the jumper settings on the system board agree 
with the hardware configuration. Run Setup and reenter data 
accounting for the indicated error. 
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Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Gate A20 failure 
The system cannot switch into protected mode. 


Call your service representative. 


Hard disk configuration error 
The specified configuration is incorrect. 


Run Setup and enter the correct fixed disk drive type. 


Hard disk controller failure 
The fixed disk controller has failed. 


Check the controller cable connections. If the message 
recurs, replace the fixed disk controller. 


Hard disk failure 
The fixed disk is defective. 


Check the system configuration and drive type, and run 
Setup. Check the controller cable. If the message recurs, 
replace the fixed disk drive. 


Hard disk read failure - 
strike Fl to retry boot 


The fixed disk is defective. 


Check the system configuration and drive type, and run 
Setup. Check the controller cable. If the message recurs, 
replace the fixed disk drive. 


hex-value Optional ROM bad checksum = hex-value 


A peripheral card contains a defective ROM or its address 
conflicts with another card. 


Replace the ROM or the peripheral card, or correct the 
address conflict. 


Intel386™ MicroComputer Model 300SX Board 


Messages 





Intel886™ MicroComputer Model 300SX Board 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Invalid configuration information - please run 
Setup program 


The memory size is incorrect, the display is configured 
incorrectly, or the number of floppy disk drives is incorrect. 


Check the system configuration and run Setup. 


Keyboard clock line failure 


Either the keyboard or the keyboard cable connection is 
defective. 


Check the keyboard connection. If connection is good, the 
keyboard may have failed. 


Keyboard controller failure 
The keyboard controller has failed. 


Call your service representative. 


Keyboard data line failure 


Either the keyboard or the keyboard cable connection is 
defective. 


Check the keyboard connection. If connection is good, the 
keyboard may have failed. 


Keyboard is locked - please unlock - 
Strike the Fl key to continue 


The keyboard lock (located at the front of the system) is 
activated. 


Unlock the keyboard and try again. 


Keyboard stuck key failure 
One or more of the keys is pressed. 


Release the key or keys and try again. 
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Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Memory address line failure at hex-value, read 
hex-value expecting hex-value 


One of the SIMMs or associated circuitry has failed. 


Check for defective SIMM and replace if necessary. If the 
message repeats, contact your service representative. 


Memory data line failure at hex-value, read 
hex-value, expecting hex-value 


One of the SIMMs or associated circuitry has failed. 


Check for defective SIMM and replace if necessary. If the 
message repeats, contact your service representative. 


Memory double word logic failure at hex-value, read 
hex-value expecting hex-value 


One of the SIMMs or associated circuitry has failed. 


Check for defective SIMM and replace if necessary. If the 
message repeats, contact your service representative. 


Memory high address line failure at hex-value, read 
hex-value expecting hex-value 


One of the SIMMs or associated circuitry has failed. 


Check for defective SIMM and replace if necessary. If the 
message repeats, contact your service representative. 


Memory odd/even logic failure at hex-value, read 
hex-value expecting hex-value 


One of the SIMMs or associated circuitry has failed. 


Check for defective SIMM and replace if necessary. If the 
message repeats, contact your service representative. 
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Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Memory parity failure at hex-value, read hex-value 
expecting hex-value 


One of the SIMMs or associated circuitry has failed. 


Check for defective SIMM and replace if necessary. If the 
message repeats, contact your service representative. 


Memory write/read failure at hex-value, read 
hex-value expecting hex-value 


One of the SIMMs or associated circuitry has failed. 


Check for defective SIMM and replace if necessary. If the 
message repeats, contact your service representative. 


No boot device available - 
strike Fl to retry boot 


If booting from a floppy disk, it is a non-bootable type or the 
floppy disk drive is defective. If booting from a fixed disk, it 
may not be formatted or the disk drive is defective. The 
problem could also be in the disk controller. 


Make sure the floppy disk in drive A contains an operating 
system floppy disk. If applicable, make sure the fixed disk 
drive contains an operating system. Check the disk 
controller. 


No boot sector on hard disk - 
strike Fl to retry boot 


The fixed disk is not formatted as a system disk. 


Format the disk with the /S option. 


No timer tick interrupt 
The timer chip on the system board may have failed. 


Contact your service representative. 
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Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Not a boot diskette - 
strike Fl to retry boot 


The floppy disk in drive A is not formatted as a system disk. 


Replace the floppy disk with a bootable system floppy disk 
and try again. 


Shadow of System BIOS failed - Executing from ROM - 
Strike the Fl key to continue 


System RAM is defective. 


Check SIMMs and replace defective module. 


Shadow of Video BIOS failed - Executing from ROM - 
Strike the Fl key to continue 


System RAM is defective or the video BIOS cannot be 
shadowed. 


Check for defective SIMMs. If none are found, run the Setup 
program and turn Shadow of Video off. 


Shutdown failure 
The keyboard controller or its associated logic has failed. 


Call your service representative. 
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Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Time-of-day clock stopped 
The external battery for the clock is probably dead. 
Replace the battery. 


Time-of-day not set - 
Please run SETUP program 


The date and time information is not set in the real-time 
clock. 


Run the Setup program and set the date and time. 
Timer chip counter 2 failed 
The timer chip on the system board may have failed. 


Contact your service representative. 


Timer or interrupt controller bad 


The timer chip or the interrupt controller on the system board 
may have failed. 


Contact your service representative. 


Unexpected interrupt in protected mode 


The system received an interrupt when in protected mode - 
probably while testing memory. 


Contact your service representative. 
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E.2.2 POST and Boot Informational Messages 


These messages do not indicate error conditions. 


Message: 


Meaning: 


Message: 


Meaning: 


Message: 


Meaning: 


Message: 


Meaning: 


Message: 


Meaning: 


Message: 


Meaning: 
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Hex-valuek Base Memory 


Indicates amount of base memory tested successfully. 


Hex-valuek extended 


Indicates amount of extended memory tested successfully. 


Hex-valuek of unshadowed memory added to extended 
memory and removed from dedicated memory. 


Indicates the amount of unused memory from 80000H 
to FOOOOH that has been added to the end of 
extended memory. 


Decreasing available memory 


Follows any memory error message. Informs you available 
memory size is adjusted to avoid use of the failed memory. 


Memory test terminated by keystroke 
The spacebar was pressed during the memory test. Reboot 


the system if you want to run to the POST. 


Strike the Fl key to continue. 





The POST detected an error prior to boot. Pressing the [Ei] 
key lets the system try to boot. 
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RUN-TIME MESSAGES 


Run-time messages are displayed if an error occurs after the boot process is 


complete. 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


Message: 


Possible Cause: 


Solution: 


1/0 card parity interrupt at address hex-value. 
Type (S)hut off NMI, (R)eboot, other keys to 
continue 


A peripheral card has failed. 


Type S to shut off the nonmaskable interrupt (NMI). This will 
temporarily allow you to continue. Replace the peripheral 
card. 


Memory parity interrupt at address hex-value. 
Type (S)hut off NMI, (R)eboot, other keys to 
continue 


One or more memory chips has failed. 


Type S to shut off the nonmaskable interrupt (NMI). This will 
temporarily allow you to continue. Check the seating of the 
SIMMs and replace any defective SIMM. 


Unexpected HW interrupt at address hex-value. Type 
(R)eboot, other keys to continue 


This could be any hardware-related problem. 


Check the hardware or call your service representative. 


Unexpected SW interrupt at address hex-value. Type 
(R)eboot, other keys to continue 


There is an error in the software program. 


Try turning the system off and then on again. If that does not 
work, check the program. 
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Message: Unexpected type 02 interrupt at address hex-value. 
Type (S)hut off NMI, (R)eboot, other keys to 
continue 


Possible Cause: There is an error in the software program. 


Solution: Try turning the system off and then on again. If that does not 
work, check the program. 


E.4 SYSTEM BOARD ERRORS 


If the POST finds an error and cannot display a message on the video display, 
the POST issues a series of beeps indicating the error and places a value in I/O 
port 80H. 


For example, a failure of bit 3 in the first 64K of RAM is indicated by a 2-1-4 beep 
code (a burst of two beeps, a single beep, and a burst of four beeps). In 
addition, the POST writes a value to I/O port 80H to enable debugging tools to 
identify the area of failure. 


Tables E-1 and E-2 list the beep codes and I/O the values that the POST writes to 
/O port 80H when it encounters error conditions. Table E-1 lists fatal errors 
(errors that halt the system). Table E-2 lists the non-fatal errors (errors that are 
not serious enough to halt the system). Both tables list other conditions that have 
no beep codes. 


One beep code is not listed in Tables E-1 or E-2: along beep followed by one or 


more short beeps indicates a video adapter failure. No beep code is sounded if 
a test is aborted while in progress. 
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Table E-1. Beep Codes for Fatal Errors 


Contents of 
YO Port 
Description of Error 80H 


386SX register test in progress 
Real-time clock write/read failure 
ROM BIOS checksum failure 
Programmable interval timer failure 
DMA initialization failure 

DMA page register write/read failure 
RAM refresh verification failure 

1st 64K RAM test in progress 

1st 64K RAM chip or data line failure multi-bit 
1st 64K RAM odd/even logic failure 
1st 64K RAM address line failure 

ist 64K RAM parity test in progress or failure 
Bit O 1st 64K RAM failure 

Bit 1 1st 64K RAM failure 

Bit 2 1st 64K RAM failure 

Bit 3 1st 64K RAM failure 

Bit 4 1st 64K RAM failure 

Bit 5 1st 64K RAM failure 

Bit 6 1st 64K RAM failure 

Bit 7 1st 64K RAM failure 

Bit 8 1st 64K RAM failure 

Bit 9 1st 64K RAM failure 

Bit A 1st 64K RAM failure 

Bit B 1st 64K RAM failure 

Bit C 1st 64K RAM failure 

Bit D ist 64K RAM failure 

Bit E 1st 64K RAM failure 

Bit F 1st 64K RAM failure 

Slave DMA register failure 

Master DMA register failure 

Master interrupt mask register failure 
Slave interrupt mask register failure 
Interrupt vector loading in progress 
Keyboard controller test failure 
Real-time clock power failure or checksum failure 
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Table E-2. Beep Codes for Non-fatal Errors 


Contents of 
YO Port 
Description of Error 80H 


Real-time clock configuration 
Screen memory test failure 

Screen initialization failure 

Screen retrace test failure 

Search for video ROM in progress 
Screen running with video ROM 
Monochrome display operable 
Color display (40 column) operable 
Color display (80 column) operable 
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F.1 INTRODUCTION 
This appendix provides a series of tables listing mapping and address 
information related to system memory and onboard devices. Topics presented 
include the following: 
e@ System memory map 
e |/O address map 
e Control port bit assignments (61H) 
e Auxiliary control port bit assignments (78H and 79H) 
@ Interrupt priority levels 
e@ DMA controller channel assignments 


e Real-time clock map 


You can find detailed information concerning the topics discussed in this 
appendix in other sections of this manual. 
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F.2 SYSTEM MEMORY MAP 


Figure F-1 illustrates the memory map for the 300SX board. 


16M 
BIOS 
FEQOO0H 


OFFFFFH 
0E0000H 


OCO000H 


1024K 










Onboard Video BIOS 


Offboard Video BIOS* 


Expanded Memory 
Conventional Memory 
Enabled in Setup 


Conventional 
Memory 





896K 

















768K 


/ 
OA0000H 





640K 





Extended 
Memory 


Figure F-1. Memory Address Map 






080000H 512K 










OK 
1024K 





* If Offboard Video is Shadowed, 
the Area from C8000H to DFFFFH 


OK is Set to Zero. 


A10008 
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F.3 I/O ADDRESSES 


Tables F-1 through F-3 list the 300SX board I/O address maps. 


Table F-1. I/O Address Map 


000-01F DMA controller-4 

020-3F Interrupt controller-1 

040-5F System timer, PIT 

O60, 064 Keyboard controller 

61 Control port 

70 NMI mask (bit 7) 

70-71 Real-time clock 

78 Aux control port 

080-09F DMA page registers 

OA0-OBF Interrupt controller-2 
OC0-ODF DMA controller-2 

OFO Clear numeric coprocessor BUSY 
OF 1 Reset numeric coprocessor 
OF8-OFF Numeric coprocessor 

102 Video display controller 
1FO-1F8 Fixed disk controller 

200-207 Game I/O port 

278-27F Parallel printer port 2 
2F8-2FF Serial port 2 

378-37F Parallel printer port 1 (primary) 
3B0-3BF Monochrome display/printer port 
3C0-3CF Enhanced graphics controller 
3D0-3DF Color/graphics controller 
3F0-3F7 Floppy disk drive controller 
3F8-3FF Serial port 1 (primary) 
400-44F Multi-terminal adapter board 
480-49F DMA page registers 

46E8 Video display controller 

56E8 Video display controller 

66E8 Video display controller 

76E8 Video display controller 
4BC4-4BC5 Video display controller 
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I/O Address 61H 


/O address 61H is an eight-bit control port. Table F-2 lists the 61H bit 
assignments. 


Table F-2. I/O Address 61H Bit Assignment 


Onboard parity error 

ISA parity error 

Speaker signal 

Refresh signal 

Enable ISA parity error 
Enable onboard parity error 
Speaker data 

Enable speaker 


7 
6 
5 
4 
3 
2 
1 
0 





I/O Address 78H 


I/O address 78H is an eight-bit auxiliary control port. Table F-3 lists the 78H bit 
assignments. 


Table F-3. I/O Address 78H Bit Assignments 


O=Enable speaker 
1=Video BIOS shadowed 
0=Floppy disk enabled 
0O=Fixed disk enabled 
0=Onboard video enabled 
1=Monochrome monitor 
0=A20 enabled 
1=Slow (CPU speed) 
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F.4 INTERRUPT PRIORITY LEVELS 


Table F-4 lists the interrupt priority assignments for the 300SX board. 


Table F-4. Interrupt Levels 


Priority | PIC Interrupt Source 
Number | Number 


Parity error detected 

Interval timer, counter 0 output 
Keyboard output buffer full 
Real-time clock 

On-board video, software 
redirected to INT OAH (IRQ2) 
Real-time clock INT 
Reserved 

Auxiliary device 

INT from math coprocessor 
Fixed disk controller 
Reserved 

Serial communications port 2 
Serial communications port 1 
Parallel port 2 

Floppy disk controller 
Parallel port 1 





OOND ahWN+ 
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t I/O port 70H bit 7 controls the NMI signal. 


The possibility of two or more interrupts demanding service at the same time 
exists. The PICs, after determining the priority of the interrupt requests, process 
the requests one at a time by transferring control of the CPU to the higher priority 
service routine first. 
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DMA CHANNEL ASSIGNMENTS 


Each DMA controller has four ports: DMA4:1. DMA1 supports channels 3:0 and 
DMA2 supports channels 7:4. Channel four is used to cascade from DMA2 to 
DMA1. Both DMA controllers support eight channels (refer to Table F-5). All 
HOLD requests for DMA1 are processed via DMA2 channel four. This forces all 
channels in DMA1 to operate at a higher priority than those in DMA2. Channel 
zero has the highest priority and channel seven the lowest. DMA channels 0-3 
are 8-bit channels and DMA channels 4-8 are 16-bit channels. 


Table F-5. DMA Channel Assignment 





REAL-TIME CLOCK MAPPING 


The 64 addressable locations in the real-time clock are divided into two areas. 
The first area includes ten bytes containing the time, calendar, alarm data, and 
four control and status bytes. The remaining area, comprised of 50 general 
purpose RAM locations, stores system configuration information (refer to Table 
F-6). 
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Table F-6. Real-time Clock Address Map 


Seconds 

Seconds alarm 

Minutes 

Minutes alarm 

Hours 

Hours alarm 

Day of week 

Date of month 

Month 

Year 

Status register A 

Status register B 

Status register C 

Status register D 
Diagnostic status byte 
Shutdown status byte 
Floppy disk drive type byte 
Reserved 

Fixed disk type byte 
Reserved 

Equipment byte 

Low base memory byte 
High base memory byte 
Low expansion memory byte 
High expansion memory byte 
Drive C extended type byte 
Drive D extended type byte 
Reserved 

Features installed 

Drive type 48 parameters 
Cache/shadow/setup 
Reserved 

2-byte CMOS RAM checksum 





(continued) 
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Table F-6. Real-Time Clock Address Map (continued) 


Low expansion memory byte 
High expansion memory byte 


Date century byte 

Setup information 

CPU speed 

Drive type 49 parameters 
Reserved 
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Hot Keys 


This appendix lists the "hot keys." Hot keys are keystroke sequences used to 
invoke special system functions. Note that in these descriptions, all numbers 
refer to numeric pad keys. 


Keystroke Sequence Function 












































Ctr] + [Att] + [insert] Enter ROM-based Setup program. 

[ctr] + [art] + (o] Enter ROM-based Setup program. 

[eu] + [Ar] + Set deturbo mode. CPU runs at 8 MHz. 
[orl] + [ar] + [2] Set turbo mode. CPU runs at 16 MHz. 
fet] + [ar] + [4] Forces default video monitor mode (CGA). 
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H.1 INTRODUCTION 


This appendix describes how to install and remove SIMMs and a 387SX numeric 
coprocessor on the 300SX board. 


H.2 INSTALLING SIMMS 


Installing SIMMs requires inserting two modules each in sockets U23 and U24. 
For each socket, insert the first SIMM module into the left-hand slot and the 
second SIMM module into the right-hand slot. To install SIMMs, perform the 
following: 


WY CAUTION 
Do not touch any electronic component unless you are properly grounded. 
Proper grounding can be established by wearing a grounded wrist strap 
or touching an exposed metal part of the system module chassis. A static 
discharge from your fingers can result in permanent damage to the 
electronic component. 


W CAUTION 
Use extreme care when installing or removing SIMMs. The plastic 
retaining clips on the sockets are easily broken by using too much force. 


1. Holding the SIMMs only by the edges, remove them from their antistatic 
package. 
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2. Position the SIMM correctly (see Figure H-1) and insert the bottom edge 
into the socket slot, beginning with the empty slot farthest to the left. 
Press down firmly while maintaining the angle of insertion. 


3. Make sure the SIMM seats correctly. If not, gently spread the retaining 
clips just enough to permit the top edge of the SIMM to be pulled away 
from the clips and reseat the SIMM. 


4. When the SIMM seats correctly, hold it at each end, and gently push the 
top edge toward the slot retaining clips until it snaps into place. 


5. Repeat steps one through four and install the remaining SIMMs into the 
socket slots, working from left to right. 


Retaining Clip 








Retaining Clip 


A10075 


Figure H-1. Installing SIMMs 
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H.3 REMOVING SIMMS 
Use the following procedures to remove SIMM modules from the system board. 


When removing SIMMs, remove them one at a time from right to left. That is, 
remove the right-hand SIMM first, and the left-hand SIMM last. 


WY CAUTION 
Apply only enough pressure on the retaining clips to release the module. 
Too much pressure can break the retaining clips or damage the socket 
slot. 


WY CAUTION 
Do not touch any electronic component unless you are properly grounded. 
Proper grounding can be established by wearing a grounded wrist strap 
or touching an exposed metal part of the system module chassis. A static 
discharge from your fingers can result in permanent damage to the 
electronic component. 


To remove a SIMM: 


1. Locate the SIMM in the right-hand slot of the right-most socket of the 
group to be removed (see Figure H-2). 


2. Gently spread the retaining clips just enough to pull the top edge of the 
SIMM away from the retaining clips. 


3. Carefully lift the SIMM away from the socket and store it in a suitable 
static-free protective wrapper. 


4. Repeat steps 2 and 3, as necessary, to remove and store SIMMs from 
the remaining sockets. 
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SIMM Socket 





Retaining Clip 
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Figure H-2. Removing SIMMs 
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H.4 


INSTALLING A NUMERIC COPROCESSOR 


Vv 


V 


CAUTION 

Do not touch any electronic component unless you are properly grounded. 
Proper grounding can be established by wearing a grounded wrist strap 
or touching an exposed metal part of the system module chassis. A static 
discharge from your fingers can result in permanent damage to the 
electronic component. 


CAUTION 

To avoid damaging the numeric coprocessor, make sure the circled 
indentation on the chip is positioned at the top left of the socket looking 
from the front of the board to the back. 


The numeric coprocessor plugs directly into the socket on the board (see 
Figure 1-2). Follow these procedures to install the numeric coprocessor: 


1. 


Remove the numeric coprocessor from its antistatic package, being 
careful not to touch the pins on the chip. 


Align the numeric coprocessor’s pins with the socket contacts. 
Position the numeric coprocessor’s pins in the socket receptacles. 


Press the chip down firmly until it seats (see Figure H-3). Be careful not 
to bend the pins. 
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Figure H-3. Installing a Numeric Coprocessor 
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H.5 REMOVING A NUMERIC COPROCESSOR 


Use the following procedures to remove the numeric coprocessor from the 
system board: 


WY CAUTION 
Do not touch any electronic component unless you are properly grounded. 
Proper grounding can be established by wearing a grounded wrist strap 
or touching an exposed metal part of the system module chassis. A static 
discharge from your fingers can result in permanent damage to the 
electronic component. 


1. | Remove the numeric coprocessor from its socket on the board (see 
Figure 1-2) using a 68-pin grid array device extraction tool. Be careful 
not to touch the device pins. 


2. Place the numeric coprocessor in an antistatic container to protect the 
device from static electricity. 


If you are transferring the numeric coprocessor to a replacement board or 
replacing a defective device, follow the procedures described in section H.4. 
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A 


A 
Ampere. 


AC 
Alternating current. A current that periodically reverses its direction of flow. 


accuracy 
In scientific measurements, accuracy is the degree of conformity to an absolute standard. For 
example, a specification of +5V + 10%, signifies how accurate +5V is with respect to the absolute 
volt as defined by the U.S. National Bureau of Standards or other governing standards organizations. 
Do not confuse accuracy with precision. Contrast with precision. 


active high 
Designates a signal that has to go high to produce an effect. 


active low 
Designates a signal that has to go low to produce an effect. 


adapter 
1. An auxiliary device or unit used to extend the operation of another system. 
2. Anelectronic part used to connect two dissimilar parts or machines. 


address 
1. Aname, label, or number identifying a location in storage, a device in a network, or any other 
data source. 
2. Anumber that identifies the location of data in memory. 


address bus 
One or more conductors used to carry the binary-coded address from the processor throughout the 
rest of the system. 


algorithm 
A finite set of well-defined rules for the solution of a problem in a finite number of steps. 


Intel3886™ MicroComputer Model 300SX Board GL-1 


Glossary 





ampere(A) 
The basic unit of electric current. 


analog 
Pertaining to data in the form of continuously variable physical quantities. Contrast with digital. 


application 
A program or set of programs used to do work on the computer. Some categories of application 
programs are word processors, database managers, spreadsheet managers, and project managers. 
Specific examples of application programs are MultiMate, dBase Ill PLUS, Lotus 1-2-3, Framework II, 
and Symphony. 


array 
An arrangement of elements in one or more dimensions. 


ASCII 
American Standard Code for Information Interchange. The code developed by ANSI for information 
interchange among data processing systems, data communications systems, and associated 
equipment. The ASCII character set consists of 7-bit control characters and symbolic characters. 


asynchronous 
In data communications, a method of transmission in which the bits included in a character or block 
of characters occur during a specific time interval. However, the start of each character or block of 
characters can occur at any time during this interval. Contrast with synchronous. 


AUTOEXEC.BAT 
A Sears alecie batch file. When you turn on your computer, or restart it by pressing the [Ct] 
[ait] + [Bel] combination, DOS searches the system disk for the AUTOEXEC.BAT file. If DOS fini finds 
one, it oi the commands in the file. 























B 


base address 
The beginning address for resolving symbolic references to locations in storage. 


base memory 
Up to 640K of memory accessible to DOS. This is also referred to as conventional memory. 
Contrast with expanded memory and extended memory. 


base register 
A general purpose register that the programmer chooses to contain a base address. 


BASIC 
A programming language that uses common English words. 
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basic input/output system 
The feature of a computer that provides a basic level of control of the major I/O devices, and relieves 
programmers of having to learn about system hardware device characteristics. 


See BIOS. 


batch file 
A file that saves time and effort and which is identified by the .BAT extension following the file name. 
If you use a sequence of DOS commands frequently, you can create a batch file containing the 
commands, and then execute the entire sequence by typing the name of the file. This reduces the 
number of keystrokes needed to execute a sequence of commands. 


binary 
1. Involving a a choice of two conditions, such as on-off or yes-no. 
2. Pertaining to a fixed radix numeration system having a radix of 2, wherein the binary digits are 0 
and 1. 


BIOS 
The feature of a computer that provides a basic level of control of the major I/O devices, and relieves 
programmers of having to learn about system hardware device characteristics. 


Acronym for basic input/output system. 


bit 
Synonym for binary digit. Either of the binary digits 0 or 1 used in computers to store information. 
(see also byte) 


bits per second (bps) 
A unit of measurement representing the number of discrete binary digits transmitted by a device in 
one second. 


board 
A rectangular piece of fiberglass that has pins on one side and electronic parts on the other; also 
called a card, PC board or PCB (printed circuit board). The system is always supplied with a system 
board. Other boards can include a video adapter board, a disk controller board, a network 
communication board, memory boards, and multifunction boards. 


boot 
(see bootstrap) 


bootstrap 
A technique or device designed to bring itself into a desired state by means of its own action; for 
example, a machine routine whose first few instructions are sufficient to bring the rest of itself into the 
computer from an input device. For example, a computer that runs DOS boots itself by causing the 
computer to read the first few of its instructions from disk. Those instructions are sufficient to read in 
the rest of DOS from disk. 


Intel386™ MicroComputer Model 300SX Board GL-3 


Glossary 





bps 
Bits per second. 


buffer 
1. An area of storage that is temporarily reserved for use in performing an input/output operation 
into which data is written or from which data is read. Synonymous with I/O area. 
2. Aportion of memory storage for temporarily holding input or output data. 


bus 
One or more conductors used for transmitting signals or power. 


byte 
1. Asequence of eight adjacent binary digits that are operated upon as a unit. 
2. Abinary character operated upon as a unit. 
3. The amount of storage used to represent one character. 


C 


Cc 
1. Celsius (centigrade). 
2. A programming language. 


cache memory 
Asmall, high-speed memory block that improves CPU performance by minimizing the number of 
memory accesses on the bus. This action is accomplished by storing the CPU's most recently used 
data/instructions in the cache memory rather than main memory. 


card 
(see Board) 


CAS 
Column address strobe; a signal that latches the column addresses in a memory chip. 


Cathode ray tube (CRT) 
A vacuum tube in which a stream of electrons is projected onto a fluorescent screen producing a 
luminous spot. The location of the spot can be controlled. A CRT is the main element in a video 
display or monitor. 


Celsius (C) 
A temperature scale; also called Centigrade. Contrast with Fahrenheit . 


Central processing unit (CPU) 
Term for processing unit; i.e. 80386. 


CFR Part 15 Subpart J 
Federal Communications Commission Specification for EMI suppression. 
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channel 
A path along which signals can be sent; for example, data channel, output channel. 


character 
A letter, digit, or other symbol. 


character generator 
1. In computer graphics, a functional unit that converts the coded representation of a graphics 
character into the shape of the character for display. 
2. In word processing, the means within equipment for generating visual characters or symbols from 
coded sets. 


character key 
A keyboard key that allows the user to enter the character shown on the key. Compare with function 
key. 


character set 
A group of characters used for a specific reason; for example, the set of characters a printer can print 
or a keyboard can support. 


Class A device 
Broadly defined, a Class A device complies with the various regulatory agencies that certify 
equipment for operation in a commercial (office or factory) environment. 


Class B device 
Broadly defined, a Class B device complies with the various regulatory agencies that certify 
equipment for operation in a home or residential environment. 


CMOS 
Complementary metal oxide semiconductor. A logic circuit family that uses very little power. It works 
with a wide range of power supply voltages. 


COM1, COM2, COM3, COM4 
These are the names DOS assigns to the serial communications port(s). Some systems only provide 
one serial port; others provide two. 


CONFIG.SYS file 
A special-purpose file that provides DOS with information about the special kinds of hardware or 
software used with the computer. Whenever the computer is turned on or rebooted by pressing [Ctr] 
+ + [Del], DOS searches the system disk for the CONFIG.SYS file. If DOS finds one, it reads the 
commands from the file and uses them to prepare the computer for operation. 














configuration 
1. The arrangement of a computer system or network as defined by the nature, number, and chief 
characteristics of its functional units. More specifically, the term configuration may refer to a 
hardware configuration or a software configuration. 
2. The devices and programs that make up a system, subsystem or network. 
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connector 
A device allowing the connection of various electrical elernents. See edge connector. 


conventional memory 
(see base memory) 


cps 
Characters per second. 


CPU 
Central processing unit. 


CRT 
Cathode ray tube. 


CSA 22.2 # 220 
Canadian Standards Association Standard for Safety of Information Processing and Business 
Equipment. 


cursor 
1. In computer graphics, a movable marker that is used to indicate position on a display. 
2. Adisplayed symbol that acts as a marker to help the user locate a point in text, in a system 
command, or in storage. 
3. A movable spot of light on the screen of a display device, usually indicating where the next 
character is to be entered, replaced, or deleted. 


cycle time 
Defines the minimum amount of time in which subsequent accesses to a DRAM device can occur. 


cylinder 
All fixed disk or diskette tracks that can be read or written without moving the disk drive or diskette 
drive read/write mechanism 


D 


data base 
A collection of data that can be immediately accessed and operated upon by a data processing 
system for a specific purpose. 


dB 
(see Decibel) 


DC 
Direct current. 
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decibel 
1. Avunit that expresses the ratio of two power levels on a logarithmic scale. 
2. Avunit for measuring relative power. 


Deutsche Industrie Norm (DIN) 
1. German Industrial Norm. 
2. The committee that sets German dimension standards. 


diagnostic 

Pertaining to the detection and isolation of a malfunction or mistake. 
digital 

Pertaining to data in the form of digits. Contrast with analog. 


DIN 
Deutsche Industrie Norm. 


DIN connector 
One of the connectors specified by the DIN committee. 


DIP 
Dual in-line package. DIPs have pins in two parallel rows. The pins are spaced 1/10 inch apart. 
(See also DIP switch.) 


DIP switch 
One of a set of small switches mounted in a dual in-line package. 


direct current (dc) 
A current that always flows in one direction. 


direct memory access (DMA) 
A method of transferring data between main storage and I/O devices that does not require processor 
intervention. 


disable 
To stop the operation of a circuit or device; specifically applied to communications ports. 


disabled 
Pertaining to a state of a processing unit that prevents the occurrence of certain types of 
interruptions. Synonymous with masked. 

disk 
Loosely, a magnetic disk. 


disk drive 
A device for storing data on and retrieving data from a fixed disk or diskette. 


Intel8386™ MicroComputer Model 300SX Board GL-7 


Glossary 





diskette 
A thin, flexible magnetic disk, permanently sealed in a protective jacket, that is used to store 
information. Synonymous with floppy and flexible disk. Most commonly available in 5.25-inch and 
3.5-inch sizes. 


display 
1. Avisual presentation of data. 
2. Adevice for visual presentation of information on any temporary character imaging device. 
3. To present data visually. 
4. See cathode ray tube. 


DMA 
Direct memory access. 


DOs 
Disk Operating System. (see operating system) 


double precision 
Pertaining to the use of two computer words to represent a number in accordance with the required 
precision. Contrast with single precision. 


DRAM 
Dynamic RAM. A type of RAM comprised of capacitive cells that require periodic refresh to maintain 
data. While the DRAM is a slower than the SRAM, its cell is much smaller. This enables the DRAM to 
be a higher density device and generally less expensive. 


drop card 
Drop cards are expansion boards that gain extra surface area by dropping down immediately after 
the 8-bit edge connector. Drop cards are not compatible in 16-bit and 32-bit expansion slots 
because the dropped portion of the card interferes with the unused connectors in these longer slots. 


dual in-line package (DIP) 
A widely used container for an integrated circuit. 


dynamic memory 
Random access memory (RAM). Read/write memory. See DRAM. 


E 


edge connector 
A terminal block with a number of contacts attached to the edge of a printed-circuit board to facilitate 
plugging into a foundation circuit. 


EIA 
Electronic Industries Association. 
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EMI 
Electromagnetic Interference. 


enable 
To initiate the operation of a circuit or device; specifically applied to communications ports. 


EPROM 
Erasable programmable read-only memory. A PROM that allows the user to change its code. 


E2-PROM 
Electrically erasable programmable read-only memory. An EPROM which allows the user to change 
its code by means of appropriate electrical signals. 


ESDI 
Enhanced Small Device Interface, which achieves faster throughput than standard fixed-disk 
controllers by shifting functionality to the fixed-disk drive. 


expanded memory 
Certain expansion boards can provide additional memory to a personal computer. Expanded 
memory is distinguished from conventional memory in that it cannot be addressed directly by DOS 
but must be accessed through the expanded memory manager. It is used directly by application 
programs such as Symphony and Framework. Contrast with extended memory. 


expansion slot 
A series of connectors mounted on the system board into which expansion boards can be inserted. 
Depending upon the system model, the type and number of expansion slots will vary. 


extended memory 
Memory whose addresses start at 1M and which can be accessed only when the processor is 
running in protected mode. Extended memory can be used by operating systems, such as UNIX, 
that run in protected mode, and by certain DOS programs, such as the RAMDRIVE.SYS virtual disk, 
that switch in and out of protected mode to perform special operations. Ordinary DOS applications 
cannot directly access extended memory. 


F 


Fahrenheit (F) 
A temperature scale. Contrast with Celsius (C). 


falling edge 
Synonym for negative-going edge. 
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fast paged mode 
A dynamic memory mode of operation that allows successive addresses to the same DRAM page 
(defined by the row addresses strobed (RAS) into the devices by simply changing the column 
addresses. In this mode, RAS is held active and the various accesses are initiated by strobing the 
new column addresses with the falling edge of CAS. The mode is available in CMOS parts and 
allows fewer cycle times. 


FCC 
Federal Communications Commission. 


field 
1. In arecord, a specified area used for a particular category of data. 
2. In adata base, the smallest unit of data that can be referred to by name. 


firmware 
1, Instructions or programs stored permanently in read-only memory (ROM) and unchangeable. 
2. Internal connections that permanently determine the function of a device or system. 

fixed disk 
A nonflexible, flat, circular plate with a magnetizable surface layer on which data can be stored by 


magnetic recording. Synonymous with hard disk. Fixed disks are permanently mounted within a 
fixed-disk drive. 


fixed disk drive 
A computer unit that consists of nonremovable magnetic disks, and a device for storing and 
retrieving data from the disks. Synonymous with hard disk drive. 


flexible disk 
See diskette. 


floppy disk 
Synonym for flexible disk. See diskette. 


floppy disk drive 
A computer unit that can store and retrieve data from floppy disks. See diskette. 


function keys 
Keys that request actions but do not display or print characters. Included are the keys that normally 
produce a printed character, but when used with the code key produce a function instead. Compare 
with character key. 


G 


G 
A symbol used to represent the prefix giga. When describing computer storage capacity, common 
usage has made G synonymous with GB, G-byte or gigabyte. 
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GB 
Abbreviation for gigabyte. 


siga 
A prefix normally used to indicate a quantity of 1,000,000,000. However, when referring to computer 
storage capacity, the prefix giga represents a quantity of 1,073,741,824 or 2 raised to the 30th 
power. 


gigabyte 
A term used when referring to computer storage capacity. A gigabyte is defined as 1,073,741,824 
bytes. 


pram (g) 
A unit of weight equivalent to 0.035 ounces. 


graphics 
A type of data created from fundamental drawing units such as lines, splines, curves, polygons, and 
so forth. 


H 


hard disk 
(See fixed disk.) 


hardware 
1. Physical equipment used in data processing, as opposed to programs, procedures, rules, and 
associated documentation. 
2. Contrast with software. 


head 
A device that reads, writes, or erases data on a storage medium; for example, a small electromagnet 
used to read, write, or erase data on a magnetic disk. 


header 
A connector located on the system board. Usually consisting of one or more rows of evenly-spaced 
pins. 


Hertz (Hz) 
A unit of frequency equal to one cycle per second. 


hex 
Common abbreviation for hexadecimal. 
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hexadecimal 
1. Pertaining to a selection, choice, or condition that has 16 possible different values or states. 
These values or states are usually symbolized by the ten digits 0 through 9, and the six letters 
A through F. 
2. Pertaining to a fixed radix numeration system having a radix of 16. 


Hz 
See Hertz. 


icon 
Icon is a term used to describe graphic display symbols commonly used on video displays. A small 
symbol that can be easily identified with a device or function; e.g., a graphics symbol of a printer or 
keyboard. Selecting the icon will allow you to access the device or function it represents. 


TEC 435 
TUV certified in accordance with International Electrotechnical Commissions Standard for Safety of 
Information Technology Equipment. 


TEC 950 
TUV certified in accordance with International Electrotechnical Commissions Standard for Safety of 
Information Technology Equipment including Electrical Business Equipment. 


input/output (I/O) 

1. Pertaining to a device or to a channel that may be involved in an input process and, at a different 
time, in an output process. Input/output may be used in place of input/output data, input/output 
signal, and input/output terminals, when such usage is clear in a given context. 

2. Pertaining to a device whose parts can be performing an input process and an output process at 
the same time. 

3. Pertaining to either input or output, or both. 


instruction 
A statement that specifies an operation to be performed by the computer, along with the values or 
locations of operands, if any exist. This statement represents the programmer's request to the 
processor to perform a specific operation. 


instruction set 
The set of instructions of a computer, of a programming language, or of the programming languages 
in a programming system. 


interface 
A device that alters or converts actual electrical signals between distinct devices, programs, or 
systems. 
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interleave 
To arrange parts of one sequence of things or events so that they alternate with parts of one or more 
other sequences of the same nature and so that each sequence retains its identity. 


interrupt 
1. Asuspension of a process, such as the execution of a computer program, caused by an event 
external to that process and performed in such a way that the process can be resumed. 
2. Inadata transmission, to take an action at a receiving station that causes the transmitting station 
to terminate a transmission. 
3. Synonymous with interruption. 


yO 
Input/Output. 


K 


K 
A symbol used to represent kilobyte, a computer storage quantity representing 1024 bytes, wherein 
1024 is equal to 2 raised to the 10th power. Common usage has made it synonymous with KB, 
Kbyte or kilobyte. See kilobyte. Contrast with k. 

k 
A symbol used to represent the prefix kilo; 1,000. 

KB 
Abbreviation for kilobyte. 

Kb 
A symbol used to represent kilobit, a computer storage quantity representing 1024 bits, wherein 1024 
is equal to 2 raised to the 10th power. 

keylock 
A device that can deactivate a keyboard (if implemented) and locks the cover on for security. 

kilo 
A prefix used to indicate a quantity of 1000. Abbreviation symbol k. Contrast with K. 

kilobyte 
A term used when referring to computer storage capacity. A kilobyte is defined as 1024 bytes. Note 
that in all other usages, the prefix kilo (k) indicates a quantity of 1,000. 

kilogram (kg) 
1000 grams. 

kilohertz (kHz) 
1000 Hertz. 
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L 


leading edge 
The first occurring edge of a pulse. 


LIM 
Lotus/Intel/Microsoft Expanded Memory Manager specification. 


LED 
Light-emitting diode. 


LPT1, LPT2, LPT3 
These are the names DOS assigns to the parallel printer ports in a system. The three names reflect 
the fact that DOS permits as many as three parallel printer ports in a system. 


M 
A symbol used to represent the prefix mega. When describing computer storage capacity, common 
usage has made M synonymous with MB, Mbyte or megabyte. See mega. 


m 
1. Prefix milli; 0.001. 
2. Meter. 

mA 


Milliampere; 0.001 ampere. 


machine language 
A language that can be used directly by a computer without intermediate processing. 


magnetic disk 
A flat circular plate with a magnetizable surface layer on which data can be stored by magnetic 
recording. 


main storage 
1. Program-addressable storage from which instructions and other data can be loaded directly into 
registers for subsequent execution or processing. 
2. Contrast with mass storage. 


mapping 
Pertaining to the geographic location for a resource within the address space. 
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masked 
Synonym for disabled. 


mass storage 
Auxiliary storage in a computer system as differentiated from RAM. Mass storage most commonly 
refers to floppy and fixed disks and magnetic tape. 


MB 
Abbreviation for megabyte. 


Mb 
A symbol used to represent megabit, a computer storage quantity representing 1,048,576 bits, 
wherein 1,048,576 is equal to 2 raised to the 20th power. 


mega 
A prefix normally used to indicate a quantity of 1,000,000. However, when referring to computer 
storage capacity, the prefix mega represents a quantity of 1,048,576 or 2 raised to the 20th power. 


megabyte 
A term used when referring to computer storage capacity. A megabyte is defined as 1,048,576 
bytes. 


memory 
Storage on electric memory such as random access memory (RAM), read-only memory (ROM), or 
CPU registers. 


MEM 
Modified frequency modulation. 


MHz 
Megahertz; 1,000,000 Hertz. 


micro (u) 
Prefix 0.000 001. 


microprocessor 
An integrated circuit that accepts coded instructions for execution; the instructions may be entered, 
integrated, or stored internally. 


microsecond (us) 
0.000 001 second. 


modified frequency modulation (MFM) 
The process of varying the amplitude and frequency of the write signal. MFM pertains to the number 
of bytes of storage that can be stored on the recording media. The number of bytes is twice the 
number contained in the same unit area of recording media at single density. MFM recording is 
commonly used on floppy- and fixed-disk drives. 
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monitor 
1. A device for visual presentation of information as temporary images. A video display. 
2. Synonym for cathode ray tube display (CRT display). 


N 
nanosecond (ns) 
0.000 000 001 second. 


negative-going edge 
The edge of a pulse or signal changing in a negative direction. Synonymous with falling edge. 


negative true 
Synonym for active low. 


network 
A group of computers connected and configured such that they can share resources. 


nonrecoverable error 
An error that makes recovery impossible without the use of recovery techniques external to the 
computer program run. 


ns 
nanosecond; 0.000 000 001 second. 


O 


OEM 
Original Equipment Manufacturer. 


offline 
Pertaining to the operation of a functional unit without the continual control of a computer. 


online 
Pertaining to the operation of a functional unit under the continual control of a computer. 

operating system 
Software that controls the execution of programs; an operating system may provide services such as 
resource allocation, scheduling, input/output control, and data management. 
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P 


paged mode 
The same basic functionality as fast paged-mode, except that the access time is the same as a 
normal RAS/CAS access. This mode is a feature on NMOS-type DRAM parts. 


PAL 
Program array logic 


parallel 

1. Pertaining to the concurrent or simultaneous operation of two or more devices, or to the 
concurrent performance of two or more activities. 

2. Pertaining to the concurrent or simultaneous occurrence of two or more related activities in 
multiple devices or channels. 

3. Pertaining to the simultaneity of tvo or more processes. 

4. Pertaining to the simultaneous processing of the individual parts of a whole, such as the bits of a 
character and the characters of a word, using separate facilities for the various parts. 

5. An alternative to serial. 


parameter 
1. Avvariable that is given a constant value for a specified application and that may denote the 
application. 


2. Aname ina procedure that is used to refer to an argument passed to that procedure. 


pel 
Picture element. 


picture element (pel) 
In computer graphics, the smallest element of a display space that can be independently assigned 
color and intensity. Synonymous with pixel. 


pixel 
The smallest displayable unit on a monitor or picture tube element. Synonymous with pel. 


platform system 
A basic OEM product-line system which combines computers or computer subsystems with special, 
unique, and proprietary hardware and/or software for added value. 


port 
An access point for data entry or exit. 


positive-going edge 
The edge of a pulse or signal changing in a positive direction. Synonymous with rising edge. 


positive true 
Synonym for active high. 
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POST 
Acronym for power-on self test. 


power-on self test 
A series of diagnostic tests that are run each time the computer's power is turned on. See POST. 


power supply 
A device that produces the power needed to operate electronic equipment. 


precision 
In science, a measure of the ability to differentiate quantities; the degree of agreement of repeated 
measurements of a quantity. Not to be confused with accuracy. 


printed circuit 
A pattern of conductors (corresponding to the wiring of an electronic circuit) formed on a board of 
insulating material. 


prtinted-circuit board 
Usually a copper-clad fiberglass board used to make a printed circuit. Also, refers to a board on 
which a printed circuit has been made. 


processing unit 
A functional unit that consists of one or more processors and all or part of internal memory. 


processor 
1. In a computer, a functional unit that interprets and executes instructions. 
2. A functional unit, a part of another unit such as a terminal or processing unit, that interprets and 
executes instructions. (see microprocessor) 


program 
A file containing a set of instructions conforming to a particular programming language syntax. 


PROM 
Programmable read-only memory. A type of ROM that contains a programmed set of code. A 
PROM code cannot be changed once programmed. See also EPROM, E2PROM and ROM. 


ptotected mode 
A mode of the 80386 microprocessor enabling it to provide advanced features, such as accessing 
large amounts of memory and enforcing hardware protection of memory segments. Current versions 
of DOS do not support protected mode operation, except for special utilities such as the 
RAMDRIVE.SYS virtual disk. 


R 


RAM 
Random access memory. Read/write memory. 
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RAS 
Row address strobe; a technique used in dynamic RAM addressing. 


RAS/CAS 
A mode of DRAM operation where every access is begun by strobing the row addresses with RAS 
and column addresses with CAS. 


raster 
In computer graphics, a predetermined pattern of lines that provides uniform coverage of a display 
space. 


tead 
To acquire or interpret data from a storage device, from a data medium, or from another source. 


tead-only memory (ROM) 
A storage device whose contents cannot be modified. The memory is retained when power is 
removed. 


recoverable error 
An error condition that allows continued execution of a program. 


tegister 
1. Astorage device, having a specified storage capacity such as a bit, a byte, or a computer word, 
and usually intended for a special purpose. 
2. Astorage device in which specific data is stored. 


reverse video 
A form of highlighting a character, field, or cursor by reversing the color of the character, field, or 
cursor with its background; for example, changing a red character on a black background to a black 
character on a red background. 


RFI 
Radio frequency interference. 


ROM 
Read-only memory. See also PROM, EPROM, and E2PROM. 


ROM BIOS 
The ROM resident basic input/output (BIOS) system which controls the major I/O devices in a 
computer system. 


RS-232C 
A standard by the Electronics Industries Association (EIA) for serial communication between 
computers and external equipment. 
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S 


scratch disk 
A scratch disk is usually a formatted floppy disk that can be used for test purposes. A floppy disk 
that contains no information of value. If data on a scratch disk is lost or destroyed during tests, it is of 
no consequence. 


sector 
That part of a track or band on a magnetic drum, a magnetic disk, or a disk pack that can be 
accessed by the magnetic heads in the course of a predetermined rotational displacement of the 
particular device. 


serial 

1. Pertaining to the sequential performance of two or more activities in a single device. The 
modifiers serial and parallel usually refer to devices, as opposed to sequential and consecutive, 
which refer to processes. 

2. Pertaining to the sequential or consecutive occurrence of two or more related activities in a single 
device or channel. 

3. Pertaining to the sequential processing of the individual parts of a whole, using the same facilities 
for successive parts. 

4. An alternative to parallel. 


setup 
1. In acomputer that consists of an assembly of individual computing units, the arrangement of 
interconnections between the units, and the adjustments needed for the computer to operate. 
2. The preparation of the system for normal operation. 


shadow memory 
A portion of RAM to which selected BIOS information is copied from ROM. This ROM-to-RAM 
copying technique is referred to as shadowing. Shadow memory is write-protected and often has 
the same addresses as the original ROM locations. Shadowing greatly enhances system 
performance because ROM information is available from fast 32-bit RAM chips instead of the slower 
ROM chips. 


signal 
A variation of physical quantity, used to convey data. 


SIMM 
Single in-line memory module. A small plug-in board containing nine DRAM chips. A SIMM DRAM 
chip is organized in a specific configuration; i.e. 256Kb x 1 or 1Mb x 1 organization. For example, 
eight 256Kb x 1 DRAM devices combine to form 256K of memory. The ninth device provides parity 
checking. 
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single precision 
Pertaining to the use of one computer word to represent a number in accordance with the required 
precision. Contrast with double precision and precision. 


software 
1. Computer programs, procedures, and rules concerned with the operation of a data processing 
system. 
2. Contrast with hardware. 


SRAM 
Static RAM. RAM comprised of static RAM chips. Unlike DRAMs, SRAMs require no refresh and are 
faster devices. The SRAM cell is larger than the DRAM cell and for this reason, SRAMs are lower 
density devices. 


static column 
A mode of operation of DRAM operation that allows successive accesses to the same DRAM page 
(defined by the row addresses initially strobed into the devices) by simply changing the column 
addresses. This mode differs from fast paged-mode because both RAS and CAS are held active, 
whereas CAS is strobed in fast paged-mode. The access time is limited to the address access time 
of the part as new column addresses are presented. 


static memory 
RAM using flip-flops as the memory elements. Data is retained as long as power is applied to the 
flip-flops. Contrast with dynamic memory. 


storage 
1. Astorage device. 
2. Adevice, or part of a device that can retain data. 
3. The retention of data in a storage device. 
4. The placement of data into a storage device. 


synchronization 
The process of adjusting the corresponding significant instants of two signals to obtain the desired 
phase relationship between these instants. 


synchronous 

1. Data transmission in which the time of transmission occurrence of each signal representing a bit 
is related to a fixed time frame. 

2. Data transmission in which the sending and receiving devices are operating continuously at 
substantially the same frequency and are maintained in a desired phase relationship by means of 
correction. 

Contrast with asynchronous. 
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T 
A symbol used to represent the prefix tera. When describing computer storage capacity, common 
usage has made T synonymous with TB, Tbyte or terabyte. 


TB 
Abbreviation for terabyte. 


tera 
A prefix normally used to indicate a quantity of 1,000,000,000,000. However, when referring to 
computer storage capacity, the prefix tera represents a quantity of 1,099,571 ,627,300 or 2 raised to 
the 40th power. 


terabyte 
A term used when referring to computer storage capacity. A terabyte is defined as 
1,099,571,627,300 bytes. 


tpi 
Tracks per inch. A specification used in formatting floppy disks and fixed disks. 


TTL 
Transistor-transistor logic. A popular logic circuit family that uses multiple-emitter transistors. 


track 
1. The path or one of the set of paths, parallel to the reference edge on a data medium, associated 
with a single reading or writing component as the data medium moves past the component. 
2. The portion of a moving data medium such as a drum, or disk, that is accessible to a given 
reading head position. 


trailing edge 
The second edge of a pulse. 


TUV 
Technischer Ueberwachungs-Verein. TUV is an testing organization that evaluates and certifies 
electronic data processing equipment to specific International safety standards. 


typematic key 
A key that repeats its function multiple times when held down. 
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UL 478 
Underwriter Laboratories Standard for Safety of Information Processing and Business Equipment. 


V 


Vv 
Volt. 


VAC 
Volts (alternating current). 


VDE 0806/IEC 380 
TUV certified in accordance with International Electrotechnical Commissions Standard for Safety of 
Electrical Energized Office Machines. 


VDE 0871 
Verband Deutscher Electrotechnikes Specification for EM! Suppression. 


vbc 
Volts (direct current). 


video 
Computer data or graphics displayed on a CRT, monitor, or display. 


video adapter 
A special board that provides a suitable interface between a computer and a video display device 
such as a CRT or monitor. A video controller. 


video controller 
A special board that provides a suitable interface between a computer and a video display device 
such as a CRT or monitor. A video adapter. 


video display 
A device for visual presentation of information as temporary images. A monitor. See also CRT. 


virtual address 
A 32-bit address on the internal bus intended to be translated by memory management. 


volt 
The basic unit of electric pressure. The potential that causes electrons to flow through a circuit. 
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WwW 
Watt. 


Watt (W) 
The basic unit of electric power. 


word 

A character string or bit string considered as an entity in computer architecture. 
write 

To make a permanent or transient recording of data in a storage device or on data medium. 
write precompensation 


The varying of the timing of the head current from the outer tracks to the inner tracks of the diskette to 
keep a constant write signal. 
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886SX CPU 1-5, 2-3 
basic bus operations 2-8 
pipelined address generation 2-9 
protected mode 2-3 
real mode 2-3 
signal descriptions 2-4 
virtual-8086 mode 2-4 

387SX numeric coprocessor 2-9 
data types 2-10 
exception conditions 2-12 
install H-5 
programming interface 2-10 

6818 real time clock (RTC) 1-6, 4-2 

8042 keyboard and mouse 

controller 1-6 

8237 DMA controller 4-49 

8254 PIT 1-6, 4-42 
control and status registers 4-43 
control register 4-44 
counter description 4-42 
counter/timer address map 4-44 
counting element 4-43 
programming 4-44 

8259A PIC 1-6, 4-28 
ICWs 4-33 
In-service register 4-29 
initialization sequence 4-36 
interrupt levels 4-30 
interrupt mask register 4-29 
Interrupt request register 4-29 
Maskable interrupts 4-30 
non-maskable interrupts 4-31 
OCWs 4-39 
priority resolver 4-29 
programming 4-32 


Intel386™ MicroComputer Model 300SX Board 


8742 keyboard controller 6-1 
80286 extended functions B-37 
82072 floppy disk drive 
controller (FDC) 1-6, 8-1 
control commands 8-9 
data rate select register 8-4 
data transfer commands 8-11 
FIFO 8-8 
main status register 8-3 
registers 8-1 
signal definitions 8-12 
82330/82331 chip set 4-1 
82335 
address mapper/decoder 3-7 
address mapping registers 3-10 
address range compare 
registers 3-15 
bus cycle translator 3-18 
chip select signals 3-16 
clock generator/reset 
synchronizer 3-21 
DRAM control registers 3-10 
memory configuration register 3-10 
numeric coprocessor interface 3-19 
parity generator/checker 3-21 
pin functions 3-22 
ready generator 3-17 
roll compare registers 3-14 
82C605 
byte format register 5-6 
communication port registers 5-3 
communications controller 5-1 
data latch register 5-13 
interrupt enable register 5-4 
interrupt flag register 5-5 
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line status register 5-9 
modem control register 5-8 
modem status register 5-10 
printer controls register 5-15 
printer status register 5-13 
receive buffer register 5-3 
transmit buffer register 5-3 


A 


Acknowledge 

mouse reply 6-20 
Acknowledge command 

keyboard controller 6-9 
Address signal group 

ISA Bus 9-5 


_Agent functional model 


ISA Bus 9-2 
Analog video monitor connector 10-6 
AT fixed disk interface 1-7 


B 


Basic bus operations 2-8 
BAT 6-9 
Battery connector 10-12 
Beep codes E-12 
BIOS 1-5 
revision level B-45 
ROM shadowing 3-7 
shadow option 11-17 
system identification string B-2 
Board features 1-1 
Boot sector B-54 
Buffers 
central processing core 2-11 
Bus agents 
ISA 9-1 


Bus cycle translator 
82335 3-18 


C 


Caps lock LED 6-11 
Central control signal group 
ISA Bus 9-10 
Character attribute B-10 
Character write B-11, B-13 
Clock 
read B-54 
Clock generator/reset synchronizer 
82335 3-21 
CMOS RAM checksum 4-23 
Color palette B-11 
COM1 5-1, 5-2, 10-4 
COM2 5-1, 5-2, 10-4 
Communication port registers 5-3 
Communication ports 5-1 
access B-31 
Component installation H-1 
Configuration of bus agents 
ISA Bus 9-2 
Configuration registers 4-15 
Connectors 10-1 
Control and status registers 
8254 PIT 4-43 
Control register 
8254 PIT 4-44 
Coprocessor 
interrupt B-59 
protected mode B-43 
Counter/timer address map 
8254 PIT 4-44 
Counting element 
8254 PIT 4-43 
CPU speed D-1 
changing with keyboard D-2 
changing with software D-3 
slowing to 8 MHz D-1 
CPU speed byte 
RTC 4-26 
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Cursor position B-7, B-8 

Cursor size B-7 

Cycle control signal group 
ISA Bus 9-7 


D 


DAC to CPU interface 7-4 
DAC0631 1-7, 7-4 
Data signal group 
ISA Bus 9-7 
Data stream 
keyboard 6-7 
mouse 6-7 
Date century byte 4-25 
Default disable command 
keyboard controller 6-13 
Default jumper settings C-1 
Deturbo mode D-1 
Device mapping F-1 
Diagnostic status byte 4-16 
Digital (TTL) monitor connector 10-6 
Digital to analog convertor 
video display subsystem 7-4 
Direct memory access signal group 
ISA Bus 9-12 
Disable command 
mouse 6-18 
Disk change line B-21 
Disk drive 
BIOS read B-17 
BIOS reset B-17 
BIOS verify B-19 
BIOS write B-18 
format B-19 
parameters B-20 
Disk HW interrupt B-4 
Display page B-8, B-9 
DMA channel assignments F-6 
DMA channels 4-52 
DMA controllers 1-5 
active cycle 4-49 
address and count registers 4-54 


base address register 4-56 
base word count register 4-56 
block transfer mode 4-50 
cascade mode 4-51 
command register 4-58 
current address registers 4-55 
current word count register 4-56 
demand transfer mode 4-50 
idle cycle 4-49 
internal registers 4-53 
mask register 4-62 
mode register 4-58 
non-register program controls 4-65 
page registers 4-56 
program control registers 4-57 
programming 4-53 
read transfer 4-52 
request register 4-61 
single transfer mode 4-50 
status register 4-63 
temporary register 4-65 
verify transfer 4-52 
write transfer 4-52 

DMA operation 4-49 

DMA timing 4-51 

DMA transfer types 4-51 

DRAM 1-5 
bank configuration 3-3 
control registers, 82335 3-10 
controller 3-3 
non-turbo mode 3-3 
page-mode operation 3-6 
refresh cycle 3-6 
resources 3-3 
roll address mapping 3-8 
shadow area 3-7 
turbo mode 3-3 

Drive C extended byte 4-22 

Drive D extended byte 4-22 
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E 


Echo command 

keyboard controller 6-9, 6-11 
Enable command 

keyboard controller 6-12 
Enable command 

mouse 6-18 
Equipment byte 4-19 
Equipment determination B-15 
Expansion slots 

maximum +5V current per slot A-4 
External interfaces 10-1 


F 


FAST.COM D-3 
Feature installed byte 4-22 
Firmware 1-5 
Fixed disk 
access indicator 10-11 
interrupt B-59 
type byte 4-19 
Fixed disk drives 
access B-23 
drive type 11-8 
Fixed disk interface 1-7 
connector 10-10 
Floppy disk drive controller 1-6, 8-1 
Floppy disk drives 
access B-16 
type byte 4-18 
Floppy disk interface connector 10-9 
Front-panel connectors 10-11 
Front-panel reset button 10-11 
FXD type 48 parameters 4-23 
FXD type 49 parameters 4-27 


G 


GD510A graphics/attributes 
chip 1-7, 7-3 

GD520A sequencer/CRT 
controller chip 1-7, 7-3 

Graphics chip set 7-3 


I 


V/O address 61H F-4 
/O address 78H F-4 
VO address maps F-3 
ICWs 4-33 
Industry Standard Architecture 
(ISA) Bus Interface 9-1 
Initialization command words 4-33 
Initialization sequence 
8259A 4-36 
Interleave operation 
DRAM 3-6 
Interrupt 
auxiliary device B-59 
clock services B-54 
controller architecture 4-28 
coprocessor B-59 
disk hardware B-4 
equipment determination B-15 
fixed disk hardware B-59 
fixed disk I/O B-23 
floppy disk drive /O B-16 
keyboard hardware B-4 
keyboard I/O B-46 
memory size information B-16 
mouse B-59 
non-maskable B-2 
print screen B-3 
printer /O B-52 
real-time clock B-58 
RS232 B-31 
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system boot B-54 
system service routines B-37 
system timer B-3 
types 4-29 
video I/O B-5 
Interrupt levels 4-30 
Interrupt mask register 4-29 
Interrupt priority assignments F-5 
Interrupt request register 4-29 
Interrupt signal group 
ISA Bus 9-12 
ISA Bus 9-1, 9-14 
address signal group 9-5 
agent functional model 9-2 
agents 9-1 
configuration of 9-2 
central control signal group 9-10 
cycle control signal group 9-7 
data signal group 9-7 
direct memory access 
signal group 9-12 
general attributes 9-4 
interrupt signal group 9-12 
power signal group 9-13 
replying agent 9-2 
requesting agents 9-1 


J 


J1 parallel port connector 10-1 
J2A serial port connector 10-4 
J2B serial port connector 10-4 
J3B Keyboard connector 10-5 
J4 mouse connector 10-6 
J5 video interface connector 10-6 
J6 video interface connector 10-6 
J11 parallel port connector 10-1 
J12 power supply connector 10-8 
J18 floppy disk interface 
connector 10-9 
J19 hard disk interface 
connector 10-10 
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J20 front-panel reset button 
connector 10-11 

J21 speaker header 10-114 

J22 fixed disk access 
indicator connector 10-11 

J23 battery connector 10-12 

J24 keylock header 10-12 

J24 power-on indicator 
connector 10-11 

Joystick interface B-41 

Jumper settings C-1 


K 


Key scan code B-4 
Keyboard 
ASCII character scan code B-50 
BAT completion code 6-9 
BAT failure code 6-9 
configuration 11-10 
connector 10-5 
data stream 6-7 
delay time B-48 
detection error 6-8 
HM interrupt B-4 
ID 6-9 
LEDs 6-11 
overrun error 6-8 
receiving data from 6-8 
sending data to 6-10 
status indicators 6-11 
typematic rate B-48 
Keyboard and mouse controller 1-6 
Keyboard buffer status B-47 
Keyboard controller 
acknowledge command 6-9 
default disable command 6-13 
echo command 6-9, 6-11 
enable command 6-12 
read ID command 6-12 
resend command 6-10, 6-14 
reset command 6-14 


Index 


IN-6 


select alternate scan 
codes command 6-11 
set all keys commands 6-13 
set default command 6-13 
set key type commands 6-13 
set typematic rate/delay 
command 6-12 
set/reset status 
indicators command 6-11 
Keyboard/mouse controller 6-1 
controller commands 6-5 
input buffer 6-4 
mouse commands 6-14 
mouse replies 6-20 
output buffer 6-4 
status register 6-2 
system interface 6-1 
Keyboard/mouse interface 6-6 
Keylock interface 10-12 
Keystroke changes B-38 


L 


Light pen position B-8 
Low and high 
base memory bytes 4-21 
extended memory bytes 4-24 
memory expansion bytes 4-21 
LPT1 5-13 
LPT2 5-13 


M 


Maskable interrupts 4-30 

Memory 
base memory configuration 11-18 
battery-backed 11-3 
configuration 3-4 
extended memory transfer B-42 


parity error B-2 
RAM 1-5 
RAM size B-16 
ROM 1-5 
Memory configuration register 
82335 3-10 
Memory map F-2 
Monitor type jumper C-3 
Monochrome displays C-3 
Mouse 
connector 10-6 
data stream 6-7 
interrupt B-59 
Mouse commands 
disable 6-18 
enable 6-18 
keyboard/mouse controller 6-14 
read data 6-17 
read device type 6-17 
resend 6-19 
reset 6-19 
reset scaling 6-15 
reset wrap mode 6-17 
set default 6-19 
set remote mode 6-17 
set resolution 6-15 
set sampling rate 6-18 
set scaling 6-15 
set stream mode 6-17 
set wrap mode 6-17 
status request 6-16 
Mouse replies 
acknowledge 6-20 
keyboard/mouse controller 6-20 
resend 6-20 


N 


NMI 4-31 

Non-maskable interrupts 4-31, B-2 

Non-register program controls 
DMA controller 4-65 

Non-turbo, DRAM controller 3-3 
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Num lock LED 6-11 
Numeric coprocessor H-5 
removal H-7 
Numeric coprocessor interface 3-19 


O 


OCWs 4-39 
Onboard RAM 3-3 
Output buffer 
keyboard/mouse controller 6-4 


P 


Page registers 
DMA controller 4-56 
Page-mode operations 
bank interleave 3-6 
DRAM 3-6 
Parallel port 1-7, 5-13 
connector 10-1 
Password 
enable/clear jumper C-4 
initialization 171-15 
PIC 1-6, 4-28 
Pipelined address generation 2-9 
PIT 1-6, 4-42 
POST 1-5, 11-1, 11-4 
configuration errors 11-2 
memory test 11-1 
reboot routine 11-1 
startup message 11-2 
POST and boot error messages 
clock chip lost power E-3 
CMOS checksum invalid E-3 
disk C 
failed initialization E-3 
diskette drive 1 seek failure E-2 
diskette read failure ... E-2 
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diskette subsystem reset failed E-3 
display adapter failed 
using alternate E-3 

floppy disk drive 0 seek failure E-2 
gate A20 failure E-4 
hard disk configuration error E-4 
hard disk controller failure E-4 
hard disk failure E-4 
hard disk read failure ... E-4 
hex-value optional ROM 

bad checksum = hex-value E-4 
incorrect configuration data 

in CMOS E-3 
invalid configuration 

information ... E-5 
keyboard clock line failure E-5 
keyboard controller failure E-5 
keyboard data line failure E-5 
keyboard is locked ... E-5 
keyboard stuck key failure E-5 
memory address line failure 

at... E-6 
memory data line failure at ... E-6 
memory double word logic 

failure at ... E-6 
memory high address line 

failure at ... E-6 
memory odd/even logic 

failure at... E-6 
memory parity failure at ... E-7 
memory size in CMOS invalid E-3 
memory write/read failure at ... E-7 
no boot device available ... E-7 
no boot sector on hard disk ... E-7 
no timer tick interrupt E-7 
not a boot floppy disk ... E-8 
shadow of system BIOS 

failed ... E-8 
shadow of video BIOS 

failed ... E-8 
shutdown failure E-8 
time or date in CMOS is invalid E-3 
timer chip counter 2 failed E-9 
timer or interrupt controller bad E-9 
time-of-day clock stopped E-9 
time-of-day not set ... E-9 
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unexpected interrupt in protected 
mode E-9 
POST and boot informational 
messages 
decreasing available memory E-10 
hex-valuek base memory E-10 
hex-valuek extended E-10 
memory test terminated by 
keystroke E-10 
strike the F1 key to 
continue, ... E-10 
POST and boot messages E-1 
POST error messages E-1 
Power signal group 
ISA Bus 9-13 
Power supply 
connector 10-8 
maximum +5V drain A-5 
Power-on indicator 10-11 
Power-on self test (see POST) 
Primary requesting agent 
ISA Bus 9-1 
Print screen B-3 
Printer port 5-13 
Priority resolver 
8259A 4-29 
Programmable interrupt controller 
(PIC) 1-6, 4-28 
Programmable interval timer 
(PIT) 1-6, 4-42 
Protected mode 2-3 


R 


RAM 1-5 

Read data command 
mouse commands 6-17 

Read device type command 
mouse commands 6-17 

Read ID command 
keyboard controller 6-12 

Read-only memory 1-5 

Ready generator 


82335 3-17 
Real mode 2-3 
Real-time clock (see RTC) 
Receiving data from the keyboard 6-8 
Refresh cycle, DRAM 3-6 
Replying agent 
ISA Bus 9-2 
Requesting agents 
ISA Bus 9-1 
Resend command 
keyboard controller 6-10, 6-14 
mouse 6-19 
Resend 
mouse reply 6-20 
Reset button 10-14 
Reset command 
keyboard controller 6-14 
mouse 6-19 
Reset scaling command 
mouse 6-15 
Reset wrap mode command 
mouse 6-17 
Roll compare registers, 82335 3-14 
ROM 1-5 
RTC 1-6, 4-2 
address map 4-8 
CMOS RAM checksum 4-23 
configuration registers 4-15 
CPU speed byte 4-26 
date century byte 4-25 
diagnostic status byte 4-16 
Drive C extended byte 4-22 
Drive D extended byte 4-22 
equipment byte 4-19 
feature installed byte 4-22 
Fixed disk type byte 4-19 
floppy disk drive type byte 4-18 
FXD type 48 parameters 4-23 
FXD type 49 parameters 4-27 
internal addressable locations 4-7 
interrupt B-58 
low and high 
base memory bytes 4-21 
extended memory bytes 4-24 
memory expansion bytes 4-21 
mapping F-6 
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RAM 1/O operations 4-5 
read B-56 
set B-56 
setup information byte 4-26 
shadow and enter setup byte 4-24 
shutdown status byte 4-17 
status registers 4-11 
A 4-11 
B 4-12 
C 4-14 
D 4-15 
Run-time messages 
/O card parity interrupt at 
address hex-value ... E-11 
Memory parity interrupt at 
address hex-value ... E-11 
unexpected HW interrupt at 
address hex-value ... E-11 
unexpected SW interrupt at 
address hex-value ... E-11 
unexpected type 02 interrupt 
at address hex-value ... E-12 


S 


Scroll Lock LED 6-11 
Secondary requesting agent 
ISA Bus 9-1 
Select alternate scan codes command 
Keyboard controller 6-11 
Sending data to the keyboard 6-10 
Serial I/O ports 5-1 
Serial port connectors 10-4 
Serial ports 1-7 
Set all Keys commands 
keyboard 6-13 
Set default command 
keyboard 6-13 
mouse 6-19 
Set key type commands 
keyboard 6-13 
Set remote mode command 
mouse 6-17 
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Set resolution command 
mouse 6-15 
Set sampling rate command 
mouse 6-18 
Set scaling command 
mouse 6-15 
Set stream mode command 
mouse 6-17 
Set typematic rate/delay command 
keyboard 6-12 
Set wrap mode command 
mouse 6-17 
Setup information byte 
RTC 4-26 
Setup program 3-4 
changing options 11-5 
date option 11-7 
display options 11-9 
drive type 11-8 
enter Setup selection 11-12 
exit 11-6, 11-19 
fixed disk drives 11-8 
floppy disk options 11-7 
keyboard option 11-10 
memory above 512K 11-18 
operations 11-4 
POST 11-4 
ROM-resident 11-3 
Screen 1 11-5 
Screen 2 11-11 
Screen 3 11-17 
shadowing options 11-17 
speaker 11-12 
stored information 11-3 
system password 11-15 
time option 11-6 
SETUP screen 1 11-5 
Shadow and enter setup byte 4-24 
Shadow DRAM area 3-7 
Shadow memory 11-17 
Shadowing 
BIOS ROM 3-7 
Shutdown status byte 4-17 
SIMMs 3-3 
installing H-1 
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Single in-line memory modules 
(see SIMMs) 
Single transfer mode 
DMA controller 4-50 
SLOW.COM D-3 
Speaker header 10-11 
Speaker interface 10-11 
Status register A 4-11 
Status register B 4-12 
Status register C 4-14 
Status register D 4-15 
Status registers 
DMA controller 4-63 
keyboard/mouse controller 6-2 
RTC 4-114 
Status request command 
mouse 6-16 
System board 
errors E-12 
physical addressing A-1 
virtual addressing A-1 
System error messages E-1 
System identification string B-2 
System reboot procedure 11-1 
System request key B-41 
System timer 
HM interrupt B-3 
read B-55 
set B-55 


F 


Timers 4-42 
Turbo mode D-1 


V 


Video display controller 
configuration 11-9 
current video mode B-13 
display mode B-6 

Video display subsystem 1-7, 7-1 
video modes 7-6 

Video I/O B-5 

Video interface 
connectors 7-8, 10-6 

Video memory 
CPU access to 7-3 
display access to 7-4 
refresh 7-3 

Video mode B-13 

Virtual-8086 mode 2-4 
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